首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

外键应该引用哪个表?

外键应该引用关联表中的主键。外键是一种约束,用于建立表与表之间的关联关系。它指示一个表中的数据值必须在另一个表中存在。在关系型数据库中,外键通常用于建立表与表之间的关系,以确保数据的完整性和一致性。

外键的引用表取决于具体的业务需求和数据模型设计。一般情况下,外键应该引用关联表中的主键,以确保数据的一致性和完整性。通过引用关联表的主键,可以建立起表与表之间的关联关系,实现数据的关联查询和数据的一致性维护。

举例来说,假设有两个表:订单表和客户表。订单表中有一个外键字段customer_id,用于关联客户表的主键字段id。这样,每个订单都必须关联一个存在于客户表中的客户。

腾讯云提供了多种云计算产品,其中包括数据库服务、服务器运维、云原生等。对于数据库服务,腾讯云提供了云数据库MySQL、云数据库MariaDB、云数据库SQL Server等产品,可以满足不同的数据库需求。关于外键的使用和管理,可以参考腾讯云数据库的官方文档:腾讯云数据库外键约束

需要注意的是,本回答不涉及亚马逊AWS、Azure、阿里云、华为云、天翼云、GoDaddy、Namecheap、Google等流行的云计算品牌商。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Django(15)关系

删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下: CASCADE:级联操作。...如果对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用的那条数据,那么就不能删除外的那条数据。 SET_NULL:设置为空。...关系 之间的关系都是通过来进行关联的。而之间的关系,无非就是三种关系:一对一、一对多、多对多等。以下将讨论一下三种关系的应用场景及其实现方式。...这个OneToOneField其实本质上就是一个,只不过这个有一个唯一约束(unique key),来实现一对一。 以后如果想要反向引用,那么是通过引用的模型的名字转换为小写的形式进行访问。...这个中间分别定义了两个引用到article和tag两张的主键。

2.1K40

django 引用自身和on_delete参数

该模型使用引用自己本身。...如果对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用的那条数据,那么就不能删除外的那条数据。如果我们强行删除,Django就会报错。...如果的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,== 前提是要指定这个字段一个默认值 ==。 SET():如果的那条数据被删除了。...; NOACTION:同 RESTRICT效果一样,也是首先先检查; CASCADE:父delete、update的时候,子表会delete、update掉关联记录; SET NULL:父delete...在进行删除A数据时,发现被约束着,使数据不能被删除,则django会先去删除约束的B数据,然后再来删除A数据。

1.3K20

oracle建、建主键、基本语法

主键:唯一标识,不能为空,加快查询速度,自动创建索引 :约束内的数据的更新,从定义时可以发现 是和主键联系,数据类型要统一,长度(存储大小)要统一。...这样在更新数据的时候会保持一致性 -创建表格语法: create table 名( 字段名1 字段类型(长度) 是否为空, 字段名2 字段类型 是否为空...); -增加主键 alter table 名 add constraint 主键名 primary key (字段名1); -增加: alter table 名...add constraint 键名 foreign key (字段名1) references 关联 (字段名2); 在建立表格时就指定主键和 create table...varchar2(8) not null, constraint PK_T_STU primary key (STU_ID) ); 主键和一起建立

3.1K50

MySQ-关系--修改结构-复制表-03

foreign key 确定字段归属方 修改 修改名 增加字段 删除字段 修改字段 复制表 复制表结构+记录 利用条件实现仅复制表结构 今日数据库操作语句 创建数据库 拆分员工与部门信息成两张... foreign key 在MySQL中通过来建立之间的硬性关系 通常将关系字段称之为字段 确定字段归属方 一对多的字段,应该建在“多”的那一方 多对多的字段建在额外的第三张上...一对一的字段建在任意一方都行,但推荐建在查询频率较高的一方(字段必须保证唯一性) 有关系的注意点 在创建的时候,必须先创建被关联 插入数据的时候也应该先插入被关联数据 级联更新,级联删除...注意外的逗号,(逗号代表一个字段的结束)(还是不要忘了建的字段定义那块最后一个语句不要加 , 逗号) 虽然能够帮你强制建立关系,但也会给两行之间增加数据相关的约束 ?...…] FIRST; # 直接移到最前面 ALTER TABLE 名 ADD 字段名 数据类型 [完整性约束条件…] AFTER 字段名; # 选择要插在哪个字段后面 删除字段 ALTER TABLE

1.1K30

为什么数据库不应该使用

接下来我们会详细介绍关系型数据库如何处理上述两种不同类型的,而我们应该如何在应用中模拟这些功能。...想要在应用程序中模拟数据库的功能其实比较容易,我们只需要遵循以下的几个准则: 向中插入数据或者修改中的数据时,都应该执行额外的 SELECT 语句确保它引用的数据在数据库中存在; 在删除数据之前需要执行额外的...,数据库会同时更新 posts 中所有引用该记录的; 当客户端删除 authors 中的记录时,数据库会删除所有与 authors 关联的记录; 不过无论是执行更新还是删除操作,数据库都可以保证各个关系之间引用的一致性和合法性不会出现引用到不存在记录的情况...当我们考虑应不应该在数据库中使用时,需要关注的核心我们的数据库承担这部分计算任务后会不会影响系统的可用性,在使用时也不应该一刀切的决定用或者不用应该根据具体的场景做决策,我们在这里介绍了两个使用时可能遇到的问题...: RESTRICT 会在更新和删除关系中的数据时对外约束的合法性进行检查,保证不会引用到不存在的记录; CASCADE 会在更新和删除关系中的数据时触发对关联记录的更新和删除,在数据量较大的数据库中可能会有数量级的放大效果

3K10

mysql如何添加一个

1:创建一个父,主键作为子表的: 1 create table province( 2 pId int primary key auto_increment, 3 pName varchar...(20) 4 ); 2:创建子表,是父的主键: 1 create table user( 2 userId int primary key auto_increment, 3 userName varchar...(40), 4 pid int, 5 foreign key(pid) references province(pId) 6 ); 给一张添加,即给子表的添加主键的规则: 在子表声明一个字段pid...int,用于作为子表的,foreign key(子表的字段) references 父名(父的主键的字段名); 3:当创建好数据时添加约束: alter table user add...foreign key(pid) references province(pId); alter table 子表的数据名 add foreign key(子表的键名称) references 父的数据名称

4.3K70

django模型中有关系的删除相关设置

0904自我总结 django模型中有关系的删除相关设置 一.一对一 例如有Author、AuthorDetail两 author = models.OneToOneField(to='Author...:作者删除详情删除,详情删除作者保留 2)作者找详情用 related_name(detail),详情找作者用 字段(author) 3)db_constraint断开关联,on_delete...(多的一方):出版社删除书不动,书删除没有任何影响 2)出版社找书用 related_name(books),书找出版社 字段(publish) 3)db_constraint断开关联...,on_delete规定逻辑关联删除动作,models.DO_NOTHING关联无动作 三.以外字段关联 1)断关联,删除关联表记录,键值置空 db_constraint=False, on_delete...2)正向找 字段,反向找 字段related_name 3)db_constraint断开关联,on_delete不存在(不设置,本质在第三张中设置,且一定是级联)

3K20

Django学习-第七讲:django 中的常用字段、字段属性,关系、操作

关系 在MySQL中,有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持约束的。的存在使得ORM框架在处理关系的时候异常的强大。...第一个参数是引用的是哪个模型,第二个参数是在使用引用的模型数据被删除了,这个字段该如何处理,比如有CASCADE、SET_NULL等。这里以一个实际案例来说明。...一个Category可以有多个文章,一个Article只能有一个Category,并且通过进行引用。...如果想要引用另外一个app的模型,那么应该在传递to参数的时候,使用app.model_name进行指定。...如果对应的那条数据被删除了,那么这条数据也会被删除。 2.PROTECT:受保护。即只要这条数据引用的那条数据,那么就不能删除外的那条数据。 3.SET_NULL:设置为空。

3.9K30

sqlserver语句创建表格_创建的sql语句

今天介绍一下如何使用SQL Server语句创建并添加数据 首先先了解一下的模式,在数据库中根据模式进行分组避免名称的冲突 在SQL Server 2014中直接新建是默认的前缀dbo 而命名其他的模式需要使用...SQL Server语句进行创建 下面将一步一步的进行演示,首先是创建一个数据库 然后创建模式在后面使用 根据创建的模式或者使用默认的模式名,进行创建,语句如下图 下面解释一下句子的意思 看一下新建好的...后面介绍如何在新表里面添加数据 根据的列数和对应的数据类型在括号中一一对应的添加数据并使用逗号隔开 注意,以上添加数据的方法需要同时添加全部字段 如果需要添加单个字段或者较多且不是全部字段则方法如下...当添加不是全部字段时注意不能为空的字段必须写入数据 最后看一下添加好数据的 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/183704.html原文链接:https

2.2K10

14.MySQL(二) 数据之操作内容操作Mysql 连接事务

primary key; alter table 名 modify 列名 int, drop primary key; 添加:alter table 从 add constraint...键名称(形如:FK_从_主表) foreign key 从(字段) references 主表(主键字段); 删除外:alter table 名 drop foreign key 键名称...2、稳定性 : 有非法数据(约束之类),事务撤回。 3、隔离性:事务独立运行。一个事务处理后的结果,影响了其他事务,那么其他事务会撤回。事务的100%隔离,需要牺牲速度。...-->要写入的内容 rollback; -->回滚到原来状态 commit; -->确认提交 MySQL支持的存储引擎只有InnoDB ,...在创建的时候 , 要求父必须有对应的索引 , 子表在创建的时候也会自动创建对应的索引

3.2K90

gorm查询嵌套结构体,嵌套预加载preload,关联,foreignkey,引用references

type BusinessUser struct { gorm.Model UserID int64 // (属于), tag `index`是为该列创建索引 BusinessID...Find(&business).Error return business, err } 注意: // 注释:Has Many一对多的引用 // 1.默认是 从中的字段为 主表模型的类型(...type)加上其 主键(ID) 生成 ,如:从card中的UserID // 2.可以改变`gorm:"foreignKey:UserName"` // 3.可以改变引用references:MemberNumber...// } // type CreditCard struct {——从 // gorm.Model // Number string // UserID uint——这个是默认(主表名...// type CreditCard struct { // gorm.Model // Number string // UserNumber string——,这个值等于User

5.5K30

Django——ContentType(与多个建立关系)及ContentType-signals的使用

也就是说,今后,我们如果自己定义model如果有关联到這个ContentType上,我们就能找到对应的model名称。...怎么从这张操作记录中得到相应操作的model呢,这就得用到fields.GenericForeignKey,它是一个特殊的,可以指向任何Model的实例,在这里就可以通过这个字段来指向类似Post...,那么此时应该怎么做呢?...是再给上面的增加一个,然后重新修改数据库么?显然是不能,一旦数据库被创建了,我们几乎很少再去修改数据,如果再给其添加额外字段,无疑会带来不必要的麻烦。...总之,如果一个与其他有多个关系,我们可以通过ContentType来解决这种关联。

4.3K20
领券