热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

go协程模型

本文主要分享【go协程模型】,技术文章【【GORM】模型关系-HasOne】为【VivaPython】投稿,如果你遇到GoWeb相关问题,本文相关知识或能到你。go协程模型一、概述HasO

本文主要分享【go协程模型】,技术文章【【GORM】模型关系-HasOne】为【Viva Python】投稿,如果你遇到Go Web相关问题,本文相关知识或能到你。

go协程模型

一、概述 HasOne与另外一个模型建立一对一的关联,这种关联表明一个模型的每个实例都包含或拥有另一个模型实例。 二、模型建立

实现HasOne模型,拥有者需要定义被拥有者的模型变量(关联模型变量),并在模型变量中指定:

(1) 外键:在被拥有者模型中定义,在关联模型变量中标注。默认为拥有者模型名ID,需要在关联模型中显式定义

(2) 引用:在拥有者模型中定义,类型要与外键变量的类型一致,在关联模型变量中标注,默认为关联模型的主键。

以用户User拥有CreditCard为例,模型定义如下:

(1) CreditCard为关联模型变量,外键默认为CreditCard模型的UserID,引用为User模型的ID

// 拥有者模型。
type User struct {
   
   ID         uint `gorm:"primary_key"`  // 默认的引用
   Password   string     `gorm:"->:false;<-"`
   CreditCard CreditCard  // 关联模型变量。
}

// 关联模型。
type CreditCard struct {
   
   ID       uint   `gorm:"primary_key"`
   UserID 	uint  // 默认的外键,需要显式定义。
   Number   string `gorm:"type:varchar(20)"`
}

(2) 建表之后,在CredictCard表中,会新增一个字段user_id,表示该CreditCard记录与之关联的User主键。

User表字段描述

user表字段描述

CreditCard表字段描述

go协程模型

三、重定义 1. 重定义外键 重定义外键,即在关联模型中指向引用的字段,需要在关联模型变量中标注。如下重定义 UserRefer为外键,使用 foreignKey标注关联模型变量 CreditCard
type User struct {
   
	ID         uint `gorm:"primary_key"`
	Name       string
	Password   string     `gorm:"->:false;<-"`
	CreditCard CreditCard `gorm:"foreignKey:UserRefer"`
}

type CreditCard struct {
   
	ID        uint `gorm:"primary_key"`
	UserRefer uint
	Number    string `gorm:"type:varchar(20)"`
}
2. 重定义引用 重定义引用,即外键指向的标识,需要在关联模型变量中标注。如下重定义 Name为引用。
type User struct {
   
   ID         uint `gorm:"primary_key"`
   Name       string
   Password   string     `gorm:"->:false;<-"`
   CreditCard CreditCard `gorm:"foreignKey:UserName;references:Name"`
}

type CreditCard struct {
   
   ID       uint `gorm:"primary_key"`
   UserName string
   Number   string `gorm:"type:varchar(20)"`
}
四、相关操作 下列的操作基于以下的 HasOne关联模型
type User struct {
   
   ID         uint `gorm:"primary_key"`
   Name       string
   Password   string     `gorm:"->:false;<-"`
   CreditCard CreditCard `gorm:"foreignKey:UserName;references:Name"`
}

type CreditCard struct {
   
   ID       uint `gorm:"primary_key"`
   UserName string
   Number   string `gorm:"type:varchar(20)"`
}
1. 保存 声明完整的结构体变量,调用 Save方法进行保存。
func TestSaveUser() {
   
   user := User{
   
      Name:     "Jason",
      Password: "12345",
      CreditCard: CreditCard{
   
         Number: "1234567890",
      },
   }
   err := SaveUser(user)
   if err != nil {
   
      log.Println("用户保存失败!")
   } else {
   
      log.Println("用户保存成功!")
   }
}
func SaveUser(user User) error {
   
   err := db.Save(&user).Error
   return err
}
2. 删除 删除实例有两种策略:

​ (1) 连同HasOne关联的对象记录删除,如上删除用户后连同账号记录一同删除。采用Select方法。如下,使用Select方法选择关联的模型,连同模型记录一同删除。

func DeleteUserByName(name string) error {
   
   var user User
   var err error
   db.Model(&user).Where("name = ?", name).First(&user)
   err = db.Model(&user).Select("CreditCard").Delete(&user).Error
   return err
}

​ (2) 不删除关联的模型记录,与(1)类型,不使用Select方法。

3. 查询

在查询时需要加载关联模型,使用Preload方法加载。

func GetUserByName(name string) (User, error) {
   
   var user User
   err := db.Model(&user).Preload("CreditCard").Where("name = ?", name).First(&user).Error
   return user, err
}

本文《【GORM】模型关系-HasOne》版权归Viva Python所有,引用【GORM】模型关系-HasOne需遵循CC 4.0 BY-SA版权协议。


推荐阅读
  • 导读上一篇讲了zsh的常用字符串操作,这篇开始讲更为琐碎的转义字符和格式化输出相关内容。包括转义字符、引号、print、printf的使用等等。其中很多内容没有必要记忆,作为手册参 ... [详细]
  • Django框架的使用教程mysql数据库[三]
    Django的数据库1.在Django_test下的view.py里面model定义模型fromdjango.dbimportmodels#Createyourmodelshere ... [详细]
  • Pro*C访问Oracle数据库的例子test.pc$cattest.pc#includeEXECSQLINCLUDESQLCA;EXECSQLBEGINDECLARESECTIO ... [详细]
  • 本文详细介绍了如何在Java中实现RSA非对称加密技术,包括生成密钥对、加密和解密操作的具体实现步骤。 ... [详细]
  • 本文详细介绍了在Hive中创建表的基本语法,包括临时表、外部表的创建方法,以及如何设置表的各种属性和约束条件。 ... [详细]
  • 本文探讨了使用匈牙利算法解决二分图中的最大权匹配问题,并通过HDU1533题目实例进行详细解析。代码实现中包括了必要的数据结构定义、输入处理以及求解过程。 ... [详细]
  • 本文详细探讨了在Windows Server 2003环境下遇到MySQL连接失败(错误代码10061)的解决方案,包括通过卸载特定的Windows更新和调整系统注册表设置的方法。 ... [详细]
  • 本文详细介绍了C++中常见的容器(如列表、向量、双端队列等)及其迭代器的实现方式,通过具体代码示例展示了如何使用这些容器和迭代器。 ... [详细]
  • 本文详细探讨了JSP环境下数据库连接的实现方法,包括环境配置、代码示例以及常见的连接问题及其解决方案。 ... [详细]
  • MySQL中如何为字段添加注释
    本文详细介绍了在MySQL数据库中为字段添加注释的两种方法,并提供了具体的SQL语句示例,帮助开发者更好地管理和理解数据库结构。 ... [详细]
  • 一、数据更新操作DML语法中主要包括两个内容:查询与更新,更新主要包括:增加数据、修改数据、删除数据。其中这些操作是离不开查询的。1、增加数据语法:INSERTINTO表名称[(字 ... [详细]
  • POJ 3472 空心方格铺砖问题(高精度计算)
    题目描述:给定一个(n+1)×(n+1)的方格,其中包含一个(n-1)×(n-1)的空洞。使用1×2的砖块进行铺设,求解不同的铺设方案总数。 ... [详细]
  • 本文探讨了使用Lighttpd与FastCGI实现分布式部署的方法。通过在中心服务器上配置Lighttpd负责请求转发,同时在多个远程服务器上运行FastCGI进程来处理实际业务逻辑,从而提高系统的负载能力和响应速度。 ... [详细]
  • Shiro功能拓展:登录失败重试次数限制
    本文详细介绍了如何在Apache Shiro框架中实现对用户登录失败重试次数的限制,通过自定义密码匹配器来增强系统的安全性。该方法不仅能够有效防止暴力破解攻击,还能确保合法用户的账户安全。 ... [详细]
  • 本文详细解析了 Mongolass 中 populate 方法的正确使用方式及其限制,特别是与 Mongoose 在使用上的差异。 ... [详细]
author-avatar
丝兰郁香
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有