吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1362|回复: 2
收起左侧

[求助] 【gorm】想在一个表中添加两个外键,只使用models自动迁移却无法生成外键

[复制链接]
thepoy 发表于 2020-7-22 08:26

想生成的表如下:

CREATE TABLE `blogs` (
  `id` int unsigned NOT NULL AUTO_INCREMENT,
  `blog_type_id` int unsigned DEFAULT NULL,
  `user_id` int unsigned DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `title` (`user_id`,`blog_type_id`),
  KEY `idx_blogs_deleted_at` (`deleted_at`),
  KEY `blogs_blog_type_id_blog_types_id_foreign` (`blog_type_id`),
  CONSTRAINT `blogs_blog_type_id_blog_types_id_foreign` FOREIGN KEY (`blog_type_id`) REFERENCES `blog_types` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
  CONSTRAINT `blogs_user_id_users_id_foreign` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

根据官方示例:

type User struct {
  gorm.Model
  CreditCards []CreditCard
}

type CreditCard struct {
  gorm.Model
  Number   string
  UserID  uint
}

models设计如下:

// Blog blog模型
type Blog struct {
        gorm.Model
        BlogTypeID uint   `json:"type_id" binding:"required"`
        UserID     uint   `json:"user_id"`
}

// User user模型
type User struct {
        gorm.Model
        Username      string     `json:"username" form:"username" binding:"required" gorm:"type:varchar(20);not null;unique"`
        Blogs         []Blog
}

// BlogType blog_type模型
type BlogType struct {
        ID    uint   `json:"id" gorm:"primary_key"`
        Type  string `json:"type" binding:"required" gorm:"not null;unique"`
        Blogs []Blog
}

自动迁移后生成的表并没有外键:

CREATE TABLE `blogs` (
  `id` int unsigned NOT NULL AUTO_INCREMENT,
  `blog_type_id` int unsigned DEFAULT NULL,
  `user_id` int unsigned DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `title` (`user_id`,`blog_type_id`),
  KEY `idx_blogs_deleted_at` (`deleted_at`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

只能用db.Models().AddForeignKey().AddForeignKey()才能添加外键,但我只想用models自动迁移。。。

请问如何设计模型才能添加这两个外键?

免费评分

参与人数 2吾爱币 +2 热心值 +2 收起 理由
woody0619 + 1 + 1 热心回复!
lei595933 + 1 + 1 用心讨论,共获提升!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

lm93129 发表于 2020-7-22 08:47
自动迁移 只会 创建表、缺失的列、缺失的索引,不会自动创建外键的,所以外键需要自己添加
 楼主| thepoy 发表于 2020-7-22 09:27
lm93129 发表于 2020-7-22 08:47
自动迁移 只会 创建表、缺失的列、缺失的索引,不会自动创建外键的,所以外键需要自己添加

好吧,我在models上纠结许久,才知道外键必须手动添加。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-30 02:12

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表