golang (Grom)关于foreignKey的使用2种方法

2023-11-22 15:40

本文主要是介绍golang (Grom)关于foreignKey的使用2种方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一种,副表使用foreignKey指向主表特定字段

type Car struct {ID          int       `gorm:"column:id;primary_key;AUTO_INCREMENT"`PlateID     string    `gorm:"column:plate_id;NOT NULL"`         // 车牌号CarSkuID    int       `gorm:"column:car_sku_id;NOT NULL"`       // 车辆sku idDriverID    int       `gorm:"column:driver_id;default:0"`       // 司机idDrivingCode string    `gorm:"column:driving_code;NOT NULL"`     // 行驶证号码OperateCode string    `gorm:"column:operate_code;NOT NULL"`     // 运营证件号码PassType    int       `gorm:"column:pass_type;NOT NULL"`        // 通行证类型PassCode    string    `gorm:"column:pass_code;NOT NULL"`        // 通行证号码Status      int       `gorm:"column:status;default:0;NOT NULL"` // 0=未启用, 1=启用CreatedAt   time.Time `gorm:"column:created_at;default:CURRENT_TIMESTAMP;NOT NULL"`UpdatedAt   time.Time `gorm:"column:updated_at;default:CURRENT_TIMESTAMP;NOT NULL"`DeletedAt   time.Time `gorm:"column:deleted_at"`CarSku  CarSku  `gorm:"foreignKey:CarSkuID"`Drivers Drivers `gorm:"foreignKey:DriverID"`
}
type CarSku struct {ID          int       `gorm:"column:id;primary_key;AUTO_INCREMENT"`Colour      string    `gorm:"column:colour;NOT NULL"`                 // 车辆颜色Type        string    `gorm:"column:type;NOT NULL"`                   // 车辆类型Specs       float64   `gorm:"column:specs;default:0.00;NOT NULL"`     // 车辆规格 (m)CarryWeight int       `gorm:"column:carry_weight;default:0;NOT NULL"` // 核载质量(kg)Volume      float64   `gorm:"column:volume;default:0.00;NOT NULL"`    // 容积(m³)Status      int       `gorm:"column:status;default:0;NOT NULL"`       // 0=未启用, 1=启用CreatedAt   time.Time `gorm:"column:created_at;default:CURRENT_TIMESTAMP;NOT NULL"`UpdatedAt   time.Time `gorm:"column:updated_at;default:CURRENT_TIMESTAMP;NOT NULL"`DeletedAt   time.Time `gorm:"column:deleted_at"`
}
func (m *CarSku) TableName() string {return "car_sku"
}
type Drivers struct {ID           int64     `gorm:"column:id;primary_key;AUTO_INCREMENT"` // 自动编号Name         string    `gorm:"column:name"`                                               // 司机姓名Mobile       string    `gorm:"column:mobile;NOT NULL"`                                    // 电话号码IdentityCard string    `gorm:"column:identity_card;NOT NULL"`                             // 身份证号码DriversCode  string    `gorm:"column:drivers_code;NOT NULL"`                              // 驾驶证号码Province     string    `gorm:"column:province"`City         string    `gorm:"column:city"`Area         string    `gorm:"column:area"`Town         string    `gorm:"column:town"`Address      string    `gorm:"column:address"`CarID        int       `gorm:"column:car_id;default:0;NOT NULL"` // 市场idStatus       int       `gorm:"column:status;default:0;NOT NULL"` // 0=未启用, 1=启用CreatedAt    time.Time `gorm:"column:created_at"`                // 创建时间UpdatedAt    time.Time `gorm:"column:updated_at"`                // 更新时间DeletedAt    time.Time `gorm:"column:deleted_at"`                // 删除时间
}func (m *Drivers) TableName() string {return "sl_drivers"
}

第一种效果:
在这里插入图片描述
第二种,副表id采用主表id

type Car struct {ID          int       `gorm:"column:id;primary_key;AUTO_INCREMENT"`PlateID     string    `gorm:"column:plate_id;NOT NULL"`         // 车牌号CarSkuID    int       `gorm:"column:car_sku_id;NOT NULL"`       // 车辆sku idDriverID    int       `gorm:"column:driver_id;default:0"`       // 司机idDrivingCode string    `gorm:"column:driving_code;NOT NULL"`     // 行驶证号码OperateCode string    `gorm:"column:operate_code;NOT NULL"`     // 运营证件号码PassType    int       `gorm:"column:pass_type;NOT NULL"`        // 通行证类型PassCode    string    `gorm:"column:pass_code;NOT NULL"`        // 通行证号码Status      int       `gorm:"column:status;default:0;NOT NULL"` // 0=未启用, 1=启用CreatedAt   time.Time `gorm:"column:created_at;default:CURRENT_TIMESTAMP;NOT NULL"`UpdatedAt   time.Time `gorm:"column:updated_at;default:CURRENT_TIMESTAMP;NOT NULL"`DeletedAt   time.Time `gorm:"column:deleted_at"`
}type CarJoinCarSkuJoinDrivers struct {CarCarSku  []*CarSku  `gorm:"foreignKey:ID"`//这个ID是指carSku表的Id你如果直接写CarSkuID会报错,编译找不到对应的字段Drivers []*Drivers `gorm:"foreignKey:ID"`
}func (m *Car) TableName() string {return "sl_car"
}

第二种效果图:
在这里插入图片描述

这篇关于golang (Grom)关于foreignKey的使用2种方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/411164

相关文章

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

golang1.23版本之前 Timer Reset方法无法正确使用

《golang1.23版本之前TimerReset方法无法正确使用》在Go1.23之前,使用`time.Reset`函数时需要先调用`Stop`并明确从timer的channel中抽取出东西,以避... 目录golang1.23 之前 Reset ​到底有什么问题golang1.23 之前到底应该如何正确的

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux