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

SQL命令 CREATE TABLE(五)

SQL支持以下外键引用操作: NO ACTION SET DEFAULT SET NULL CASCADE NO ACTION-删除行或更新被引用表中的键值时,将检查所有引用表,以查看是否有任何行引用要删除或更新的行...如果是,则删除或更新失败。(如果外键引用自身,则此约束不适用。)。默认情况下不执行任何操作。无操作是切片表支持的唯一引用操作。...SET NULL-删除行或更新被引用表中的键值时,将检查所有引用表,以查看是否有任何行引用要删除或更新的行。如果是,则该操作会导致引用要删除或更新的行的外键字段设置为NULL。外键字段必须允许空值。...SET DEFAULT-删除行或更新被引用表中的键值时,将检查所有引用表,以查看是否有任何行引用要删除或更新的行。如果是,则该操作会导致引用要删除或更新的行的外键字段设置为该字段的默认值。...如果是这样,则删除操作会导致其外键字段引用要删除的行的行也被删除。 在被引用表中更新行的键值时,将检查所有引用表,以查看是否有任何行引用要更新的行。

1.8K50

MySQL数据库与JDBC编程

PRIMARY KEY 4、FOREIGN KEY:外键,指定该行记录从属于主表中的一条记录,主要用于保证一个或两个数据表之间的参照完整性。...1、指定两列的联合外键 CREATE TABLE 表名( Sname VARCHAR(255), Spass VARCHAR(255), CONSTRAINT 约束名 FOREIGN KEY(...Sname, Spass) REFERENCES 主表名(Fname, Fpass) ); 2、级联删除(定义当删除主表记录时,从表记录也会随之级联删除/从表记录的外键设置为null) CREATE...创建索引: 1、自动 当在表上定义主键约束、唯一约束、外键约束时,系统自动创建对应的索引。...为了让批量操作可以正确地处理错误,必须把批量执行的操作视为单个事务,如果批量更新在执行过程中失败,则让事务回滚到批量操作开始之前的状态。

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

    YashanDB数据完整性

    外键的值,要么匹配被引用主键或唯一键的值,要么为空。如果复合外键中存在空值列,该键的非空列不再强制要求匹配父项中的对应列。被引用键被外键所引用的表中的唯一键或主键。...依赖表又称“子表”,外键约束所在的表。被引用表又称“父表”,被子表的外键引用的表。该表中的被引用值决定了在子表中特定的插入或更新是否可被允许。...# 父表的修改与外键的关系删除或更新父表数据可能会破坏外键约束。...DELETE SET NULL 删除置空(DELETE SET NULL)是指当父表被删除时,对应被引用键值在子表中的所有行的外键被设置成NULL。...UPDATE SET NULL 更新置空(UPDATE SET NULL)是指当父表更新时,对应被引用键值在子表中的所有行的外键被设置成NULL。

    5900

    Mysql外键约束

    外键是用来实现参照完整性的,不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。...如果父表试图UPDATE或者DELETE任何子表中存在或匹配的外键值,最终动作取决于外键约束定义中的ON UPDATE和ON DELETE选项。...CASCADE: 从父表中删除或更新对应的行,同时自动的删除或更新自表中匹配的行。ON DELETE CANSCADE和ON UPDATE CANSCADE都被InnoDB所支持。 2....SET NULL: 从父表中删除或更新对应的行,同时将子表中的外键列设为空。注意,这些在外键列没有被设为NOT NULL时才有效。...外键约束使用最多的两种情况: 1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败; 2)父表更新时子表也更新,父表删除时子表匹配的项也删除。

    5.9K81

    SQL表之间的关系

    SQL表之间的关系要在表之间强制执行引用完整性,可以定义外键。修改包含外键约束的表时,将检查外键约束。定义外键有几种方法可以在InterSystems SQL中定义外键:可以定义两个类之间的关系。...定义关系会自动将外键约束投影到SQL。可以在类定义中添加显式外键定义(对于关系未涵盖的情况)。可以使用CREATE TABLE或ALTER TABLE命令添加外键。...外键引用完整性检查外键约束可以指定更新或删除时的引用操作。 在CREATE TABLE reference action子句中描述了使用DDL定义这个引用操作。...参照完整性检查失败会生成如下错误:错误#5540:SQLCODE:-124消息:表'HealthLanguage.FKey2'中至少存在1行,该行引用键NewIndex1-外键约束'NewForeignKey1...默认情况下,当删除带有外键的行时,InterSystems IRIS将在相应的被引用表的行上获取长期(直到事务结束)共享锁。这样可以防止在引用行上的DELETE事务完成之前对引用行进行更新或删除。

    2.5K10

    外键的设置

    FOREIGN KEY test(字段2) #外键 REFERENCES test2(字段2) #约束表字段 ON DELETE CASCADE #父表删除子表更新方式 ON UPDATE CASCADE...; #父表更新子表更新方式 2、可视化界面设置 选中表—》关/系/外键 | F10 ——》外部键 约束名自动生成不用管,重点是后面的更新和删除关键字 三、相关关键字含义 外键约束(表2)...对父表(表1)的含义: 在父表上进行update/delete以更新或删除在子表中有一条或多条对应匹配行的候选键时,父表的行为取决于:在定义子表的外键时指定的on update/on delete子句...,直到使用删除键值的辅助表被手工删除,并且没有参照时(这是默认设置,也是最安全的设置)NO ACTION啥也不做 四、外键约束使用最多的两种情况: 场景关键字选择①父表更新时子表也更新,父表删除时如果子表有匹配的项...,删除失败;ON UPDATE CASCADE ON DELETE RESTRICT;②父表更新时子表也更新,父表删除时子表匹配的项也删除。

    2.8K30

    【MySQL】外键约束介绍

    官方文档: https://dev.mysql.com/doc/refman/5.7/en/create-table-foreign-keys.html 1.外键作用: MySQL通过外键约束来保证表与表之间的数据的完整性和准确性...2.外键的使用条件 1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持) 2.外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引...) NO ACTION(无动作,默认的) CASCADE:表示父表在进行更新和删除时,更新和删除子表相对应的记录 RESTRICT和NO ACTION:限制在子表有关联记录的情况下,父表不能单独进行删除和更新操作...SET NULL:表示父表进行更新和删除的时候,子表的对应字段被设为NULL 4.案例演示 以CASCADE(级联)约束方式 1....因此父表中不可删除相对应记录,即兵种表还有属于西欧的兵种,因此不可单独删除父表中的西欧势力 update country set id=8 where id=1; #错误,子表中有相关记录,因此父表中无法修改

    5.1K20

    第13章_约束

    (3)创建 (CREATE) 表时就指定外键约束的话,先创建主表,再创建从表 (4)删表时,先删从表(或先删除外键约束),再删除主表 (5)当主表的记录被从表参照时,主表的记录将不允许删除,如果要删除数据...,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据 (6)在 “从表” 中指定外键约束,并且一个表可以建立多个外键约束 (7)从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,...,要求主表必须存在 删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除 # 6.7 约束等级 Cascade方式 :在父表上 update/delete 记录时,同步 update...不建外键约束,你的操作(创建表、删除表、添加、修改、删除)不受限制,要保证数据的 引用完整性 ,只能依 靠程序员的自觉 ,或者是 在Java程序中进行限定 。...外键与级联更新适用于 单机低并发 ,不适合 分布式 、 高并发集群 ;级联更新是强阻塞,存在数据库 更新风暴 的风险;外键影响数据库的 插入速度 。 # 7.

    39330

    MySQL数据库,从入门到精通:第十三篇——MySQL数据表约束详解

    ( 3 )创建(CREATE)表时就指定外键约束的话,先创建主表,再创建从表 ( 4 )删表时,先删从表(或先删除外键约束),再删除主表 ( 5 )当主表的记录被从表参照时,主表的记录将不允许删除,...如果要删除数据,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据 ( 6 )在“从表”中指定外键约束,并且一个表可以建立多个外键约束 ( 7 )从表的外键列与主表被参照的列名字可以不相同,...删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除 6. 7 约束等级 Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录...不建外键约束,你的操作(创建表、删除表、添加、修改、删除)不受限制,要保证数据的引用完整性,只能依靠程序员的自觉,或者是在Java程序中进行限定。...外键与级联更新适用于单机低并发,不适合分布式、高并发集群;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的插入速度。 7.

    24610

    MySQL基础

    当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与 RESTRICT 一致) RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与 NO ACTION 一致) CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录。...SET NULL 当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为 null(这就要求该外键允许取 null)。...子查询:标量子查询、列子查询、行子查询、表子查询 # 事务 事务简介:事务是一组操作的集合,这组操作,要么全部执行成功,要么全部执行失败。

    1K30

    【Java】已解决com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException异常

    这个异常通常表明在执行数据库操作时违反了数据完整性约束,例如主键冲突、外键约束不满足、唯一约束冲突等。这类问题往往出现在插入、更新或删除数据库记录的场景中。...二、可能出错的原因 主键冲突:尝试插入一个已经存在主键值的记录。 外键约束不满足:尝试插入或更新一个记录,但其外键值在相关表中不存在。...四、正确代码示例 为了避免这个异常,我们应该在插入或更新记录之前进行校验,确保不违反任何完整性约束。...由于我们省略了主键字段(假设它是自增的),因此不会发生主键冲突。 五、注意事项 数据校验:在插入或更新数据库记录之前,始终进行必要的数据校验,以确保不违反任何完整性约束。...数据类型匹配:确保Java代码中的数据类型与数据库中的数据类型相匹配,以避免因数据类型不匹配导致的错误。

    39710

    【Java】已解决:org.springframework.dao.DataAccessException

    当应用程序尝试执行数据库操作(例如查询、插入、更新或删除)时,如果发生任何数据访问错误,Spring会抛出这个异常。...具体场景可能包括: 数据库连接失败 SQL语法错误 数据类型不匹配 违反数据库约束 例如,在一个Spring Boot应用程序中,尝试通过JDBC模板查询数据库时,可能会遇到这个异常。...如果SQL查询存在问题或数据库连接失败,就可能抛出DataAccessException。...: 无法获取JDBC连接 可能导致该异常的原因包括: SQL语法错误:例如拼写错误、关键字使用错误等。...数据库连接问题:数据库服务器不可用或配置错误。 数据类型不匹配:Java对象和数据库表的字段类型不一致。 违反约束条件:如违反唯一约束或外键约束。

    41510

    MySQL(笔记)

    清除已有语句:\c 数据管理 外键(了解即可) 外键概念 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。由此可见,外键表示了两个关系之间的相关联系。...此时,第二个表中保存这些值的属性称为外键(foreign key)。 外键作用 保持数据一致性,完整性,主要目的是控制存储在外键表中的数据,约束。...使两张表形成关联,外键只能引用外表中的列的值或使用空值。...创建外键 建表时指定外键约束 -- 创建外键的方式一 : 创建子表同时创建外键 -- 年级表 (id\年级名称) CREATE TABLE `grade` ( `gradeid` INT(10)...不合规范的表设计会导致的问题: 信息重复 更新异常 插入异常 无法正确表示信息 删除异常 丢失有效信息 三大范式 第一范式 (1st NF) 第一范式的目标是确保每列的原子性

    1.5K10

    MySQL学习笔记汇总(四)——表的约束、存储引擎、事务

    username varchar(255) ); 外键约束:foreign key 外键主要是维护表之间的关系的,主要是为了保证参照完整性,如果表中的某个字段为外键 字段,那么该字段的值必须来源于参照的表的主键...外键可以为NULL 被外键引用的字段不一定是主键,但至少具有unique约束。...顺序要求: 删除数据的时候,先删除子表,再删除父表。 添加数据的时候,先添加父表,在添加子表。 创建表的时候,先创建父表,再创建子表。 删除表的时候,先删除子表,在删除父表。...InnoDB 优点:支持事务、行级锁、外键等。这种存储引擎数据的安全得到保障。...表的结构存储在xxx.frm文件中 数据存储在tablespace这样的表空间中(逻辑概念),无法被压缩,无法转换成只读。 这种InnoDB存储引擎在MySQL数据库崩溃之后提供自动恢复机制。

    1.7K50

    SQL命令 INSERT(三)

    尝试为具有列级ReadOnly (SELECT或REFERENCES)权限的字段插入值将导致SQLCODE -138错误:无法为只读字段插入/更新值。...此设置不适用于用NOCHECK关键字定义的外键。 在INSERT操作期间,对于每个外键引用,都会在引用表中相应的行上获得一个共享锁。 在执行引用完整性检查和插入该行时,此行被锁定。...这确保了引用的行不会在引用完整性检查和插入操作完成之间发生更改。 但是,如果指定了%NOLOCK关键字,则不会对指定的表或引用表中相应的外键行执行锁操作。...子表插入 在对子表执行INSERT操作期间,父表中相应行的共享锁将被获取。 在插入子表行时,此行被锁定。 然后释放锁(直到事务结束才持有锁)。 这确保在插入操作期间不会更改引用的父行。...分片表始终没有自动事务模式,这意味着对分片表的所有插入、更新和删除都是在事务范围之外执行的。

    2.5K10

    SQL命令 TRUNCATE TABLE

    tablename - 要从中删除所有行的表。 还可以指定一个可更新视图,通过该视图可以删除表中的所有行。 表名(或视图名)可以是限定的(schema.table)或非限定的(table)。...如果删除一行会违反外键引用完整性,那么TRUNCATE TABLE将失败。 未删除任何行,因此TRUNCATE TABLE发出SQLCODE -124错误。 这个默认行为是可以修改的,如下所述。...Fast Truncate 限制 快速截断可以应用于标准表或分片表。 不能应用快速截断: 如果用户无法获得表级锁(除非指定了%NOLOCK)。 如果表是外键约束的目标。...指定约束参数限制处理如下: %NOCHECK - 禁止对引用被删除行的外键进行引用完整性检查。 %NOLOCK - 抑制被删除行的行锁定。 这应该只在单个用户/进程更新数据库时使用。...如果在删除父记录时指定了约束参数,则在删除相应的子记录时将应用相同的约束参数。

    1.8K30

    【MySQL】:约束全解析

    KEY (外键字段名)REFERENCES 主表 (主表列名) ; 删除外键 ALTER TABLE 表名 DROP FOREIGN KEY 外键名称; 3.3 删除/更新行为 添加了外键之后,再删除父表数据时产生的约束行为...具体的删除/更新行为有以下几种: 行为 说明 NO ACTION 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不 允许删除/更新。...(与 RESTRICT 一致) 默认行为 RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不 允许删除/更新。...(与 NO ACTION 一致) 默认行为 CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则 也删除/更新外键在子表中的记录。...SET NULL 当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表 中该外键值为null(这就要求该外键允许取null)。

    28310

    2024Mysql And Redis基础与进阶操作系列(4)作者——LJS

    如果要删除数据,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据 在“从表”中指定外键约束,并且一个表可以建立多个外键约束 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致...(外键约束失败) (`atguigudb`....,要求主表必须存在删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除 1.7 约束等级 Cascade方式 在父表上update/delete记录时,同步update/delete...,则不允许对父表对应候选键进行update/delete操作 Restrict方式 同no action, 都是立即检查外键约束 Set default方式 (在可视化工具SQLyog中可能显示空白)父表有变更时...不建外键约束,你的操作(创建表、删除表、添加、修改、删 除)不受限制,要保证数据的引用完整性 ,只能依靠程序员的自觉 ,或者是在Java程序中进行限定 。

    11310

    MySQL数据库操作教程

    :FOREIGN KEY --外键约束要求: --1.父表和子表必须使用相同的存储引擎,而且禁止使用临时表 --2.数据表的存储引擎只能为InnoDB /* 3.外键列和参照列必须具有相似的数据类型。...外键约束的参照操作及功能: 1.CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行 2.SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL (ps.如果使用该选项,...必须保证子表列没有指定NOT NULL) 3.RESTRICT:拒绝对父表的删除或更新操作 4.NO ACTION:标准SQL的关键字,在MySQL中与RESTRICT相同 --例子 CREATE...外键约束的参照操作及功能: 1.CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行 2.SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL (ps.如果使用该选项,...必须保证子表列没有指定NOT NULL) 3.RESTRICT:拒绝对父表的删除或更新操作 4.NO ACTION:标准SQL的关键字,在MySQL中与RESTRICT相同 --例子 CREATE

    4.8K10

    轻松学习SQL外键约束的核心原理和实用技巧

    它是指表中某个字段的值依赖于另一张表中某个字段的值,而被依赖的字段必须且有主键约束或者唯一约束。被依赖的表通常称之为父表或者主表,设置外键约束的表称为子表或从表。...相关概念主键:可以唯一标识一条记录的列外键:从表中与主表的主键对应的字段主表:外键所指向的表,约束其他表的表从表:外键所在的表,被约束的表价值:建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性建立外键约束创建表时添加外键约束...=2级联删除删除主表数据的同时,也删除掉从表中相关的数据ON DELETE CASCADE#创建员工信息表并添加级联删除的外键约束CREATETABLEemp_part(emp_idINTPRIMARYKEYAUTO_INCREMENT...id=2的部门DELETEFROMdeptWHEREid=2#查看从表中的数据是否同时被删除SELECT*FROMemp_part总结SQL 中的外键约束是一种参照完整性约束,它用于确保两个表之间的数据一致性...当在子表中插入或更新数据时,外键约束确保所提供的外键值必须在父表的相应主键或唯一键值范围内。如果父表中不存在相应的值,则操作将失败,从而确保了数据的完整性和一致性。

    32510
    领券