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

MySQL 学习笔记(三):完整性和触发器设计

*/ /*定义sno为外键参考student表的主键sno,并且实现级联删除更新SC表中相应的元组 */ /* 提示 foreign key .. references ... on delete...cascade on update cascade, /*定义Cno为外键参考course表的主键Cno,并且实现级联删除SC表中相应的元组 */ );  2....删除约束 删除主键约束:alter table 表名 drop primary key; 删除外键约束:alter table 表名 drop foreign key 外键(区分大小写);...这里我创建外键的时候 sno 中有些表有主键约束,有些却没有,所以当我删除主键约束的时候它会提示外键被错误建立起来了。但我不明白为什么建立外键的时候没有报错。...创建触发器 在MySQL中,创建触发器语法如下: CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH

1.5K40

《深入浅出SQL》问答录

有办法确定外键已经连接到父键了吗? A:外键为NULL,表示在父表中没有相符的主键。但我们可以确认外键包含有意义、已经存储在父表中的值,请通过约束实现。...如果我们试着删除主键表中的行或者是改变主键值,而这个主键是其他表的外键约束时,你就会收到错误警告。 所以上面说的那种,我就不能删除了是吗? A:还是可以的,先移除外键行即可。...外键约束 创建一张表并加上可作为外键的列虽然很简单,但除非你利用CREATE或ALTER语句来指定外键,否则都不算是真的外键。创建在结构内的外键被称为约束。...插入外键列的值必须已经存在与父表的来源中,这是引用完整性。 创建外键作为表的约束提供了明确的优势,如果违反了规则,约束会阻止我们破坏表。 外键不一定要是父表的主键,但是要具有唯一性。 ?...因为当SELECT语句的结果是一个虚表时,若没有别名,SQL就无法取得其中的表。 为什么视图对数据库有好处? 如果创建了视图,就不需要重复创建复杂的联接与子查询。视图隐藏了子查询的复杂性。

2.9K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL基础--> 约束(CONSTRAINT)

    key (字段名)references 表名(字段名)--->foreign 三、建表时约束定义 1.定义各种不同的约束 --创建一个用于作外键的表tb_dept SQL> CREATE TABLE...SET NULL: 子表中相应的列置空 如果子表在建外键时,该列的数据并不在父表,则无法创建该约束。...外键约束对update语句的影响: 主从表都有可能违反外键约束,操作一个表必须将另一个表的数据处理好。 外键约束对DDL语句的影响: 删除主表时,才有可能违约约束。...,当主表中的一行数据被删除时,ORACLE自动将从表中依赖于它的记录外键也删除。...tb_cons2 2 DROP CONSTRAINT uk_tb_cons2_email; 使用下面的方法可以级联删除主表主键及从表的外键 ALTER TABLE table_name DROP

    1.7K20

    Django模型最佳实践

    字段对应到数据库表中的列名,未指定时直接使用字段的名称 db_index 设置为True时将在该字段创建索引 db_tablespace 为有索引的字段设置使用的表空间,默认为DEFAULT_INDEX_TABLESPACE...default 字段的默认值 editable 字段在后台模型管理或ModelForm中是否显示,默认为True error_messages 设定字段抛出异常时的默认消息的字典,其中的键包括null...db_constraint:是否为外键创建约束,默认值为True。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...through:指定维持多对多关系的中间表的Django模型。 throughfields:定义了中间模型时可以指定建立多对多关系的字段。 db_table:指定维持多对多关系的中间表的表名。

    2.3K40

    MySQL:表的约束

    而如果为我们没有在创建表的时候显示声明默认值,MySQL会优化,自动加上默认值为NULL。 四....自增长的特点: 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)。 自增长字段必须是整数。 一张表最多只能有一个自增长。 为什么会这样呢?...唯一键 创建带有唯一键的表: 唯一键表达了类似于主键的功能,不能发生冲突。 但是,唯一键是可以为空的,这是区别于主键的地方。 主键与唯一键并不冲突,是互相补充的!!!...外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。...外键需要注意: (1)从表和主表的关联关系 (2)产生外键约束 总结: 好了,到这里今天的知识就讲完了,大家有错误一点要在评论指出,我怕我一人搁这瞎bb,没人告诉我错误就寄了。

    6710

    第三章《数据表的基本操作》

    ,…) 2.用修改表的方法也可以添加主键: ALTER TABLE 表名 ADD PRIMARY KEY (字段名) 2.3使用外键: 外键用来在两个数据表之间建立连接,它可以是一列,也可以是多列...(字段) REFERENCES 父表名 (父表主键列) 注意; 1.关联的父表列,一定是父表的主键列 2.关联的父表如果为联合主键是,先关联联合主键中的第一个字段 3.关联父表时,被关联的外键的数据类型要和父表主键的数据类型一致...,否则关联失败 4.关联父表时,父表和子表的存储引擎必须为InnoDB,MyISAM引擎不支持外键功能。...5.要避免书写错误 6.如果两个表之间有外键关联,如果我们想要删除父表,必须先解除外键的关系,或者先删除掉子表, 否则无法删除父表 2.4使用非空约束 非空约束指字段的值不能为空 语法: 在创建表时...: drop table 表1,表2,表N… [IF EXISTS]:不加这个,如果我们要删除的表不存在就会报错,加上呢,不存在也会执行删除操作,不会返回错误信息 注意:如果我们要删除的表是另一个设置了外键的表的父表

    1.2K10

    第三章《数据表的基本操作》

    注意; 1.关联的父表列,一定是父表的主键列 2.关联的父表如果为联合主键是,先关联联合主键中的第一个字段 3.关联父表时,被关联的外键的数据类型要和父表主键的数据类型一致,否则关联失败 4.关联父表时...5.要避免书写错误 6.如果两个表之间有外键关联,如果我们想要删除父表,必须先解除外键的关系,或者先删除掉子表, 否则无法删除父表 2.4使用非空约束 非空约束指字段的值不能为空 语法: 在创建表时...3.9 删除数据表; 语法 : drop table 表1,表2,表N… [IF EXISTS]:不加这个,如果我们要删除的表不存在就会报错,加上呢,不存在也会执行删除操作,不会返回错误信息 注意...:如果我们要删除的表是另一个设置了外键的表的父表,无法直接删除,我们需要先删除外键或者是把子表删掉,才可以删除这个表; ?...3.10 删除表的外键约束: 语法: alter table 表名> drop foreign key 外键名> ; 注意:如果没有设置外键名,外键名就是字段名; 3.11 删除表的主键约束;

    1.4K10

    SQL命令 CREATE TABLE(五)

    定义外键 外键是引用另一个表的字段;存储在外键字段中的值是唯一标识另一个表中的记录的值。...,外键引用另一个表的主键字段。...在RowID上定义外键时必须省略引用的字段名;尝试将ID显式指定为引用的字段名会导致SQLCODE-316错误。 如果这些默认值都不适用,IRIS将发出SQLCODE-315错误。...指称动作子句 如果一个表包含外键,对一个表的更改会对另一个表产生影响。为了保持数据的一致性,在定义外键时,还需要定义外键数据所来自的记录的更改对外键值的影响。...相反,当DELETE或UPDATE操作遇到这些相互矛盾的外键定义时, SQL会发出错误。 下面是一个嵌入式SQL示例,它发出一条使用两个引用动作子句的CREATE TABLE语句。

    1.8K50

    MySQL表的约束

    创建表时约束不为空:not null create table myclass( class_name varchar(20) not null, class_room varchar(...对于我们所创建的表,会发现在一个整形数据类型中带有括号字段。...删除主键约束 这样,插入的数据就可以重复,但是通过观察,仍不能为空,因为not null在创建表时的添加约束期间会一并添加到约束。不过有了主键,才能更好的查找数据,因为其具有唯一性。...如果将学生表和班级表结合成一个表,那么在插入数据时,就需要插入大量的字段造成没必要的冗余。若将其分成两个表,那么通过一一对应的映射,来减少没必要的数据。 为什么会造成没必要的冗余?...外键是用于定义主表和从表之间的关系 外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

    22650

    【MySQL 系列】MySQL 语句篇_DDL 语句

    DELETE 返回删除的行数; 如果一个表被其他表的外键引用,对此表的 TRUNCATE 操作会失败。 2.3、数据列操作 MySQL 允许您使用 ALTER TABLE 语句来修改一个现有的表。...如果主键包含多个列,则这些列的值组合起来必须是唯一的。 主键列中不能包含 NULL 值。 3.1.1、创建主键 我们可以在创建表时定义主键。...注意,当你向一个有数据的表中添加主键时,由于主键要求列的值是唯一的并且不能为 NULL,如果该列中有重复的值或者 NULL 值,则会返回错误。...你也不能为一个城市设定一个不存在的 country_id,否则这个城市数据就是错误的。 3.2.1、创建外键 通常,外键所属的表被称作子表,被外键引用的表被称作父表。...3.2.2、添加外键 如果建表的时候没有定义外键,你也可以后来通过以下语法添加外键: ALTER TABLE child_table_name ADD [CONSTRAINT foreign_key_name

    32410

    【愚公系列】2022年01月 Mysql数据库-约束

    数据库常见六大约束如下: 1.主键约束 2.非空约束 3.自增长约束 4.非负约束 5.唯一约束 6.外键约束 2.约束作用 数据的完整性是指数据的正确性和一致性,可以通过定义表时定义完整性约束,也可以通过规则...:非空和唯一两个功能 一张表只能有一个列作为主键 主键一般用于表中数据的唯一标识 建表时添加主键约束 -- 标准语法 CREATE TABLE 表名( 列名 数据类型 PRIMARY KEY,...建表时添加外键约束 为什么要有外键约束 -- 创建db2数据库 CREATE DATABASE db2; -- 使用db2数据库 USE db2; -- 创建user用户表 CREATE TABLE...) REFERENCES 主表名(主表主键列名) 创建表添加外键约束 -- 创建user用户表 CREATE TABLE USER( id INT PRIMARY KEY AUTO_INCREMENT...(uid) REFERENCES USER(id); 7.外键的级联更新和级联删除 什么是级联更新和级联删除 当我想把user用户表中的某个用户删掉,我希望该用户所有的订单也随之被删除 当我想把

    55810

    约束

    如果是多个列的组合,那么默认的名字就是第一个字段的名字 MySQL会给唯一约束的列默认创建一个唯一索引 创建表的时候进行添加约束: sqlCREATE TABLE student2( sno VARCHAR...创建主键约束时,系统默认建立对应的主键索引。...FOREIGN KEY约束 外键约束 外键约束会涉及到主表和从表 主表(父表):被引用的表 从表(子表):引用别人的表 从表的外键必须引用主表的主键或者唯一性约束的列 在创建外键的时候,如果不给外键约束的话...,默认名不是列名,而是自动产生一个外键名,当然也可以指定外键约束名 创建表的顺序,先创建主表,再创建从表 删表,先删从表,再上主表 从表的外键列和主表的列名字可以不相同,但是数据类型必须一样。...当创建外键约束时,系统默认会在所在的列上创建对应的普通索引,索引名就是外键的约束名。

    80520

    【愚公系列】2023年03月 Java教学课程 100-MySQL数据库(约束)

    KEY ON UPDATE CASCADE 外键级联更新 在修改主表中的记录时,自动更新与其关联的从表中的记录。...FOREIGN KEY ON DELETE CASCADE 外键级联删除 在关系型数据库中,当一个表的某个记录被删除时,该表中的外键所关联的记录也会被自动删除的过程。...建表时添加外键约束 为什么要有外键约束 -- 创建db2数据库 CREATE DATABASE db2; -- 使用db2数据库 USE db2; -- 创建user用户表 CREATE TABLE...) REFERENCES 主表名(主表主键列名) 创建表添加外键约束 -- 创建user用户表 CREATE TABLE USER( id INT PRIMARY KEY AUTO_INCREMENT...当我想把user用户表中的某个用户id修改,我希望订单表中该用户所属的订单用户编号也随之修改 添加级联更新和级联删除 -- 添加外键约束,同时添加级联更新 标准语法 ALTER TABLE 表名 ADD

    47200

    SqlAlchemy 2.0 中文文档(五十四)

    我收到关于“在属性 Y 下隐式组合列 X”的警告或错误 我正在使用声明式并使用 and_() 或 or_() 设置 primaryjoin/secondaryjoin,但我收到了关于外键的错误消息...a_id = Column(Integer, ForeignKey("a.id")) 我正在使用声明式语法,并使用and_()或or_()设置primaryjoin/secondaryjoin,但是我收到了关于外键的错误消息...a_id = Column(Integer, ForeignKey("a.id")) 我正在使用声明式并使用and_()或or_()设置 primaryjoin/secondaryjoin,并且收到有关外键的错误消息...我已经针对外连接创建了映射,但是虽然查询返回行,但没有返回对象。为什么? 由外连接返回的行可能包含主键的部分 NULL,因为主键是两个表的组合。Query对象忽略不具有可接受主键的传入行。...我已经创建了一个针对 Outer Join 的映射,虽然查询返回了行,但没有返回对象。为什么? 外部连接返回的行可能会对主键的某部分包含 NULL,因为主键是两个表的组合。

    36310

    【重学 MySQL】四十七、表的操作技巧——修改、重命名、删除与清空

    如果表中有外键约束,并且这些外键被其他表引用,则可能无法直接 TRUNCATE 该表。 TRUNCATE TABLE 会重置表的自增计数器(AUTO_INCREMENT)。...此外,DELETE操作会触发相关的触发器和外键约束。...触发器和外键约束 TRUNCATE TABLE:TRUNCATE操作不会触发与表相关的触发器,也不会检查外键约束。因此,如果表被其他表的外键所引用,则可能无法直接TRUNCATE该表。...DELETE FROM:DELETE操作会触发与表相关的触发器,并且会检查外键约束。如果尝试删除的行被其他表的外键所引用,则DELETE操作会失败并返回错误。...使用建议 如果需要快速清空表中的所有数据,并且不关心自增主键计数器的重置、触发器的触发或外键约束的检查,可以使用TRUNCATE TABLE。

    13310

    Java面经整理(三)---数据库之视图

    主键、超键、候选键、外键 主键: 数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。一个数据列只能有一个主键,且主键的取值不能缺失,即不能为空值(Null)。...外键: 在一个表中存在的另一个表的主键称此表的外键。...视图还可以被嵌套,一个视图中可以嵌套另一个视图。 6 . 视图创建的规则和限制 与表一样,视图必须唯一命名(不能给视图取与别的视图或表相同的名字)。 对于可以创建的视图数目没有限制。...这是默认行为,而且是允许的,但有的DBMS可能会防止这种情况发生。 7.为什么要使用视图(View)?...4、表只用物理空间而视图不占用物理空间,视图只是逻辑概念的存在,表可以及时对它进行修改,但视图只能有创建的语句来修改。 5、表是内模式,视图是外模式。

    1.2K20

    【Mysql】:linux环境下表的三部曲(数据操作 + 类型解析 + 约束规则)

    创建主键有两种方法: 创建表的时候就把主键设置好 表建好之和但没有主键,可以追加主键 【案例 1】:创建表的时候就把主键设置好 mysql> create table t7(id int primary...产生外键约束 为什么需要外键约束?...外键 用于定义 主表 和 从表 之间的关系: 外键约束主要定义在从表上 主表则必须是有主键约束或 unique 约束 当定义外键后,要求外键列数据必须在主表的主键列存在或为 NULL 在从表中,设置外键约束...,这样,当业务调整的时候,我们可以尽量不会对主键做过大的调整 3.8 外键(foreign Key) 外键: 从表和主表的关联关系 产生外键约束 为什么需要外键约束?...外键 用于定义 主表 和 从表 之间的关系: 外键约束主要定义在从表上 主表则必须是有主键约束或 unique 约束 当定义外键后,要求外键列数据必须在主表的主键列存在或为 NULL 在从表中,设置外键约束

    3700

    安全的数据库图形管理工具(4):SQL语句(2)

    但一般情况下都要设置主键,如果联合主键字段太多就会导致性能下降。 外键约束 外键约束在关系数据库的一对多关系和多对多关系中最常见,一个表可以有多个外键,每一个外键都必须和另一个表或者当前表的主键关联。...之所以我要多设置一个字段ID,是因为可能存在用户刷屏情况,如果同一个用户在一秒内发了两次相同的消息,这样的话就会出现完全重复的两行(时间也只不过精确到秒而已),从而导致各种错误。 ?...) REFERENCES 表名(字段名f1) /*外键约束,字段名f可以是当前表的另一个字段,也可以是其他表的某个字段*/ ... ); 创建表的SQL语句封装就有一些复杂了,因为可以填写的信息太多了...这一点也不难,封装成方法只要两个参数,第一个参数是表名,第二个参数是一个字典:键是字段名,值是字段值。 DELETE FROM 表名 (WHERE 条件) 当一个表的数据太多,会影响数据库性能。...DROP TABLE 表名 当我们想要删除数据库的一张表,就执行对应的SQL语句,语法如同标题所示。下面我来演示一下,如图所示。 ? 这个SQL语句封装成方法只要一个参数就行,这个参数是表名。

    76920

    mysql基本命令

    charset=utf8 创建含主键的表 create table 表名(列名 数据类型 primary key,列名 数据类型 constraint fk_外键名 foreign key (列名[,]...table 表名;清除表(如果有自增id,id 会重新开始) 4.修改表结构 alter table 表名 auto_increment=value;设置自增键起始值; alter table 表名...autocommit我们默认开启,否则每次都需手动提交太麻烦,但当我们想开启一个事务时应该怎么做?...,BTree 每层节点数多,层数少,减少了IO读写次数,查询结果更加稳定 5.主键 外键 主键:数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。...一个表只能有一个主键,且主键的取值不能缺失,即不能为空值(Null)。 外键:在一个表中存在的另一个表的主键称此表的外键。

    1.3K10
    领券