PRIMARY KEY 约束是可以组合在一起使用的。一列中可以同时加上多个约束。...注意: 实际开发中,大部分的表,一般都会带有一个主键,主键往往是一个整数表示的id 在mysql中,一个表里,只能有一个主键,不能有多个 虽然主键不能有多个,mysql允许把多个列放到一起共同作为一个主键...(联合主键) 主键另外一个非常常用的方法,就是使用mysql自带的“自增主键”作为主键的值。...外键约束,是父表对 子表做了约束,但与此同时。子表也在反过来约束了父表。 id为1,被子表引用了,因此被约束,无法删除id为1的数据。 id为2,没有被引用,可以删除。...但是如果表不是一一对应,内连接和外连接就有区别了。 左外连接:会把左表的结果尽量列出来,哪怕在右表中没有对应的记录,就使用NULL填充。
,外键关联/引用/参照主键,主键和外键的数据类型必须一致。 ...) references 主表(主表主键字段); 在表中修改:constraint FK_主表_子表_主表主键字段 foreign key(子表外键字段) references 主表(主表主键字段...设计从表可以有两种方案: 方式1:在t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束;即:字段 字段类型 unique, 方式2:给t_card表的主键添加外键约束...通常连接查询不可能需要整个笛卡尔积,而只是需要其中一部分,那么这时就需要使用条件来去除不需要的记录。 这个条件大多数情况下都是使用主外键关系去除(一般使用内连接查询)。 ...特别注意:我自己测试过,两张表的主外键关系可以alter修改表的主次表关系,使这两张表有了主外键关系; 两种表也可以不有主外键关系,只要他们对应的字段和字段类型相同就行。
我主张起单数表名,下面是来自《SQL Server 2000 宝典》的一段引用: 主张用复数表名的阵营认为:表是由一组记录构成的,所以应当使用复数名词来命名它。...这个表中字段分别命名为StudentId、CourseID(既是此表的复合主键,同时分别为连接Student表和Course表的外键,等下到主键和外键的命名处再说),这样就实现了学生和课程之间的多对多关系...外键的命名 外键的命名为 fk_外键所在的表名_外键引用的表名。因为外键所在的表为从表,所以上式可以写为 fk_从表名_主表名。 外键包含的字段的命名,外键包含的字段和外键是完全不同的概念。...在Hotel表中,CityId是做为外键使用。...接着我按照 表、字段、主键、外键、触发器、存储过程的顺序,详细讲述了数据库对象命名的规则。
本系列出自《深入浅出MySQL》,全文以问答形式展开,是我的个人学习笔记。 问答录 先看花絮 Q:如果外键是NULL,它右什么作用吗?有办法确定外键已经连接到父键了吗?...A:外键为NULL,表示在父表中没有相符的主键。但我们可以确认外键包含有意义、已经存储在父表中的值,请通过约束实现。...---- Q:不能单纯的使用另一张表的键,称之为外键,而不加上约束吗? A:其实可以,但创建成外键约束后,就只能插入已经存在于父表中的值,有助于加强两张表间的连接。...如果我们试着删除主键表中的行或者是改变主键值,而这个主键是其他表的外键约束时,你就会收到错误警告。 ---- Q:所以上面说的那种,我就不能删除了是吗?...插入外键列的值必须已经存在与父表的来源中,这是引用完整性。 创建外键作为表的约束提供了明确的优势,如果违反了规则,约束会阻止我们破坏表。 外键不一定要是父表的主键,但是要具有唯一性。
单系统应用可以使用自增主键不适用于多系统 手动赋值可以确保在系统中的唯一性 06-外键和连接:如何做关联查询? 多表查询:把分散在多张表中的数据查询出来。...外键(FOREIGN KEY)和连接(JOIN)将多张表关联。 设计外键 有两张表A、B通过id进行关联,如果Id在A中时主键,那么A便称为主表,B表就是从表,B表中的id字段就是外键。.../image-20210602212346409.png)] 外键约束 从表中定义定义的外键指定外键字段、对应主表中的字段,MySQL会根据外键约束的定义,监控主表中数据的删除操作,如果发现要删除的主表记录...,但不能使用分组中的计算函数作为筛选条件,HAVING必须要与GROUP BY配置使用,可以把分组计算的函数和分组字段作为筛选条件 在需要对数据进行分组统计的时候,HAVING可以完成WHERE不能完成的任务...你以为 EXPLAIN 就一定准吗 ? 执行计划在真正执行的时候是可能改变的! 绝大多少情况下是适用的,特别是 EXPLAIN 08-聚合函数:怎么高效的进行分组统计?
有办法确定外键已经连接到父键了吗? A:外键为NULL,表示在父表中没有相符的主键。但我们可以确认外键包含有意义、已经存储在父表中的值,请通过约束实现。...不能单纯的使用另一张表的键,称之为外键,而不加上约束吗? A:其实可以,但创建成外键约束后,就只能插入已经存在于父表中的值,有助于加强两张表间的连接。 加强连接?是什么意思?...如果我们试着删除主键表中的行或者是改变主键值,而这个主键是其他表的外键约束时,你就会收到错误警告。 所以上面说的那种,我就不能删除了是吗? A:还是可以的,先移除外键行即可。...外键约束 创建一张表并加上可作为外键的列虽然很简单,但除非你利用CREATE或ALTER语句来指定外键,否则都不算是真的外键。创建在结构内的外键被称为约束。...插入外键列的值必须已经存在与父表的来源中,这是引用完整性。 创建外键作为表的约束提供了明确的优势,如果违反了规则,约束会阻止我们破坏表。 外键不一定要是父表的主键,但是要具有唯一性。 ?
可以看到其被标识为了主键,但是在创建时并没有指定它是主键,而是这一列的属性基本满足了主键的要求,如唯一、不可以为空。...说外键的主要作用是:保持数据的一致性、完整性。听得我是一头雾水,表示没有听懂。...比方学生表有个学生编号(sid),分数表中的学生列(stu)引用学生表的学 生编号,此时对于分数表的 stu 来说。学生表的 sid 就是外键。 从表也叫外键表,主表也叫主键表、外表,列也叫字段。...所以在设计的时候。就给表1加入一个外键,这个外键就是表2中的学号字段。那么这样表1就是主表,表2就是子表。 你的主从关系理解颠倒了。你的图中,表1的确是主表。...表2是子表,但不是叫做给表1加入一个外键,而是给表2加入一个外键,表2中的学号 字段就叫外键,它是表1学号字段的主键。
成本参考以下几点: 这里我再贴个链接,先给使用外键的优点这边投一票 :外键的好处 那既然他这么好,为什么我不推荐你使用呢?...这样的后果之一是BLOB和TEXT列不被包括在一个外键中,这是因为对这些列的索引必须总是包含一个前缀长度 InnoDB不对那些外键或包含NULL列的被引用键值检查外键约束 关于对SQL标准的背离(这里只贴其中一个点...但不使用物理外键的我们也有方案去实现我们的逻辑外键,并保证他正确运行。 数据库上的一个策略:可以选择大多数情况下我们只更新不删除,也就是逻辑删,不再使用的历史数据定期归档来减少压力。...即使你对业务理解深刻,对外键也掌握的透彻,你也不太希望老是你管一部分他管一部分吧? 五、反对的声音 最后再来说说一些坚持用外键的思考 有人问:原本在物理外键的开销,在程序上不也有开销吗?...对于关系型数据库正确性>性能的说法,如果逻辑复杂到一定程度,物理外键一定能给你提供正确性吗?这个可以讨论讨论。 最后,我这里送个东西 MySQL 5.1参考手册
10.在使用索引字段作为条件时,如果该索引是复合索引,那么必须使用到该索引中的第一个字段作为条件时才能保证系统使用该索引,否则该索引将不会被使用,并且应尽可能的让字段顺序与索引顺序相一致。...我主张起单数表名,下面是来自《SQL Server 2000 宝典》的一段引用:主张用复数表名的阵营认为:表是由一组记录构成的,所以应当使用复数名词来命名它。...这个表中字段分别命名为StudentId、CourseID(既是此表的复合主键,同时分别为连接Student表和Course表的外键,等下到主键和外键的命名处再说),这样就实现了学生和课程之间的多对多关系...在Hotel表中,CityId是做为外键使用。...而对于多对多关系中解析表的外键包含的字段,顺理往下推,我们可以这样写(再次回到学生选课的多对多例子中): 建立解析表StudentCourse与Student表的外键关系: Alter Table StudentCourse
D、自定义完整性:用户自己定义的业务规则,比如使用触发器实现自定义业务规则。 ? 2、数据完整性实现方式 ? MySQL不支持Check约束,虽然可以在列上添加check约束,但不起作用。...每个表最多只允许一个主键,建立主键约束可以在列级别创建,也可以在表级别上创建。...3、自增主键 AUTO_INCREMENT PRIMARY KEY 如果不指定主键值,会自动在现有主键值的最大值上自动增加1作为新记录的主键,主键值默认从1开始。...如果外键约束指定了参照动作,主表记录做修改,删除,从表引用的列会做相应修改,或不修改,拒绝修改或设置为默认值。 引用表的列名必须是主键,且在删除引用表时必须删除引用关系或者删除当前表。...删除成绩表的外键约束 ALTER TABLEscoreDROP FOREIGN KEYscore_fk; 增加成绩表的sid列外键约束,参照动作为set null ALTER TABLEscoreADD
联合主键体现在多个表上,复合主键体现在一个表中的多个字段。 复合主键 主键通常定义在表的一列上,但这并不是必需的,也可使用多个列作为主键。...外键 在一个表中存在的另一个表的主键称此表的外键 主键的选择 数据库中的每一条记录都需要有一个唯一的标识,依据数据库第二范式,数据库中每一个表中都需要有一个唯一的主键,其他数据元素和主键一一对应。...而对于用户表来说,我们需要考虑的是作为主键的业务字段是否能够唯一标识一个人,一个人可以有多个email和手机号,一旦出现变更email或者手机号的情况,就需要变更所有引用的外键信息,所以使用email或者手机作为主键是不合适的...因此,我更倾向于使用生成的ID作为数据库的主键。不单单是因为它的唯一性,更是因为一旦生成就不会变更,可以随意引用。...在单库单表的场景下,我们可以使用数据库的自增字段作为ID,因为这样最简单,对于开发人员来说也是透明的。 代理主键(推荐使用) 与业务无关的,无意义的数字序列。
使用NHibernate实现一对多,多对一的关联很是简单,可如果要用复合主键实现确实让人有些淡淡的疼。虽然很淡疼但还是要去抹平这个坑,在下不才,愿意尝试。...优化代码如下: //外键与联合主键不要共用字段 [ManyToOne(0, Name = "Parent", ClassType = typeof(Foo))] [Column(1, Name = "...ParentId")] [Column(2, Name = "ParentGroupNumber")] public virtual Foo Parent { get; set; } 说明: 1.由于联合外键与联合主键共用了一个字段...,导致映射出错 四、终于实现了,总结 类都必须可以序列化,也就是要还serializable标注 继承BaseInfo实现联合主键(不推荐使用) 在Save时,如果用session.merge方法组合缓存与修改对象...,返回值的主键会为Null 联合主键与联合外键字段不能重复,也不能共用 注意重载的GetHashCode和Equals方法 GetHashCode返回实例的惟一标识 Equals判断是否相同实例的具体实现
;一个主键可以定义在一个或多个字段;主键使一个或多个字段的值必须唯一且不为空,这样做可以通过该字段或该组字段中的值唯一的代表一条记录。...唯一属性:一个表中只能有一个主键属性,为了方表用户,提出唯一约束;唯一约束可以定义在一个或多个字段上;唯一约束使该字段或该组字段中的值唯一,可以为空,但是,不能重复。...外键属性:又叫外键,又叫外键约束,跟主键和主键约束的关系是一样的;外键约束针对的两个表,如果表A的主关键字是表B中的字段,则该字段称为表B的外键,表A称为主表,表B称为从表,但要注意,必须要计算机要知道你是这种关系...(你知道为什么建立主键和唯一约束的时候,会自动的创建索引吗?而且是唯一索引,想一想索引大多在那些字段上用,以及索引的作用就会知道了。...像主键约束、唯一约束、非空约束、外键约束、核查约束和缺省约束这些操作都是使表具有某些特性,所以在这里我认为他们都是表的属性。)
大多数情况下,你需要的这些数据都存储在DBMS(数据库管理系统)中。 为了与DBMS进行交互和通信,你需要使用它的语言或它能理解的语言。用于与DBMS交互的语言是SQL(结构化查询语言)。...关系数型据库(Relational Databases) 数据存储在关系数据库的不同表中,每个表都包含多条记录(行)。这些表使用一种或多种关系相互连接。 键定义了表之间的关系。...键是表字段(列),其包含每条记录的唯一值。如果将一个字段定义为表的主键,则该字段可以包含在多个表中,并且可以用于同时访问不同的表。一旦使用主键将其表连接到另一个表,它将在另一个表中被称为外键。...这两个表已连接,以“PilotId”作为飞行员表的主键。我可以用飞行员的ID来访问飞行员表中有关飞行员的信息以及航班表中该飞行员正在处理的航班信息。...1 r2I2zlm5bmvfs9UHWqTF-A.png 因此,在飞行员表中,PoilotId是主键;而在航班表中,它是外键。PilotId在此用于形成两个表之间的关系。
可以用主键子句或者主键短语来定义 建表时定义主键 添加主键 参照完整性:又称引用完整性,指标简的规则,卓用于有关联的两张或两张以上的表,通过使用主键和外键(或为一键)之间的关系,使表中键值在相关表中保持一致...,主键 和外键不是必须有的,但是为了安全尽量使用。...java和数据库的对应关系)给表中的一个字段添加一个外键属性(从表),让它由相应的主键约束(主表),与其他表的主键构成关联关系,主键约束外键。...//给表中添加外键 create table student ( id int primary key auto_increment,//主键设置每张表都有,并且在代码的第一行...foreign key外键 一张表的外键可以关联另外一张表的主键,而保证数据的完整性。
数据库常见六大约束如下: 1.主键约束 2.非空约束 3.自增长约束 4.非负约束 5.唯一约束 6.外键约束 2.约束作用 数据的完整性是指数据的正确性和一致性,可以通过定义表时定义完整性约束,也可以通过规则...完整性约束存在数据字典中,在执行SQL或PL/SQL期间使用。用户可以指明约束是启用的还是禁用的,当约束启用时,他增强了数据的完整性,否则,则反之,但约束始终存在于数据字典中。...:非空和唯一两个功能 一张表只能有一个列作为主键 主键一般用于表中数据的唯一标识 建表时添加主键约束 -- 标准语法 CREATE TABLE 表名( 列名 数据类型 PRIMARY KEY,...(uid) REFERENCES USER(id); 7.外键的级联更新和级联删除 什么是级联更新和级联删除 当我想把user用户表中的某个用户删掉,我希望该用户所有的订单也随之被删除 当我想把...user用户表中的某个用户id修改,我希望订单表中该用户所属的订单用户编号也随之修改 添加级联更新和级联删除 -- 添加外键约束,同时添加级联更新 标准语法 ALTER TABLE 表名 ADD CONSTRAINT
KEY ON UPDATE CASCADE 外键级联更新 在修改主表中的记录时,自动更新与其关联的从表中的记录。...FOREIGN KEY ON DELETE CASCADE 外键级联删除 在关系型数据库中,当一个表的某个记录被删除时,该表中的外键所关联的记录也会被自动删除的过程。...2.主键约束 主键约束特点 主键约束包含:非空和唯一两个功能 一张表只能有一个列作为主键 主键一般用于表中数据的唯一标识 建表时添加主键约束 -- 标准语法 CREATE TABLE 表名(...(uid) REFERENCES USER(id); 7.外键的级联更新和级联删除(了解) 什么是级联更新和级联删除 当我想把user用户表中的某个用户删掉,我希望该用户所有的订单也随之被删除...当我想把user用户表中的某个用户id修改,我希望订单表中该用户所属的订单用户编号也随之修改 添加级联更新和级联删除 -- 添加外键约束,同时添加级联更新 标准语法 ALTER TABLE 表名 ADD
因此,在设计表的时候,不建议使用过长的字段为主键,也不建议使用非单调的字段作为主键,这样会造成主索引频繁分裂。 4、说一下MySQL是如何执行一条SQL的?具体步骤有哪些? ?...25、数据库中的主键、超键、候选键、外键是什么?(很棒) 超键:在关系中能唯一标识元组的属性集称为关系模式的超键 候选键:不含有多余属性的超键称为候选键。也就是在候选键中,若再删除属性,就不是键了!...主键:用户选作元组标识的一个候选键程序主键 外键:如果关系模式R中属性K是其它模式的主键,那么k在模式R中称为外键。...主键:简单的说,例子中的元组的候选键为学号,但是我们选定他作为该元组的唯一标识,那么学号就为主键。...外键是相对于主键的,比如在学生记录里,主键为学号,在成绩单表中也有学号字段,因此学号为成绩单表的外键,为学生表的主键。 主键为候选键的子集,候选键为超键的子集,而外键的确定是相对于主键的。
3NF:3NF 在 2NF 的基础之上,消除了非主属性对于码的传递函数依赖 。 5. 主键和外键有什么区别? 主键(主码) :主键用于唯一标识一个元组,不能有重复,不允许为空。一个表只能有一个主键。...外键(外码) :外键用来和其他表建立联系用,外键是另一表的主键,外键是可以有重复的,可以是空值。一个表可以有多个外键。 6. 为什么不推荐使用外键与级联?...说明: 以学生和成绩的关系为例,学生表中的 student_id 是主键,那么成绩表中的 student_id 则为外键。...,因为即使你不使用外键,你在应用层面也还是要保证的。...所以,我觉得这个影响可以忽略不计。) 外键还会因为需要请求对其他表内部加锁而容易出现死锁情况; 对分库分表不友好 :因为分库分表下外键是无法生效的。 ......
除MySQL强制实施的规则外,还应该坚持的最佳实践: 不更新主键列中的值 不重用主键列的值 不在主键列中使用可能会更改的值 例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时...联合主键体现在多个表上,复合主键体现在一个表中的多个字段。 复合主键 主键通常定义在表的一列上,但这并不是必需的,也可使用多个列作为主键。...,就不算重复 超键 在关系中能唯一标识元组的属性集称为关系模式的超键。...一个属性可以为作为一个超键,多个属性组合在一起也可以作为一个超键。超键包含候选键和主键。 候选键 是最小超键,即没有冗余元素的超键。...外键 在一个表中存在的另一个表的主键称此表的外键 主键的选择 代理主键(推荐使用) 与业务无关的,无意义的数字序列。
领取专属 10元无门槛券
手把手带您无忧上云