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

再谈表的约束

自增长 auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。...:唯一键就可以解决表中有多个字段需要唯一性约束的问题。...是一样的,就会插入失败: 唯一键可以为空: 外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。...: 在从表中插入班级id为1和2都是可以的,但是插入的班级id为3,由于外键约束,导致插入失败。...删除主表中班级id为1 的班级: id为1的班级里面还有学生,由于外键约束导致删除失败。

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

    MySQL表的约束

    而这个字段就代表着整形int的数据的最大长度,一般的数据达不到这样的长度,那么如果使用zerofill约束,就会用0将没用到的位置进行占位。 插入数据: 可以看出二者的区别。...删除主键约束 这样,插入的数据就可以重复,但是通过观察,仍不能为空,因为not null在创建表时的添加约束期间会一并添加到约束。不过有了主键,才能更好的查找数据,因为其具有唯一性。...唯一键和主键的区别: 在使用中,主键是标识唯一性,而唯一键是保证业务中的数据唯一性。 主键一个表只能有一个,唯一键可以有多个。 主键不能为空,唯一键可以为空,甚至多个为空。...因此,这就需要让两个表产生联动,插入class_id=3的学生的前提是存在id=3的班级,删除id=1的班级最后会连着学生表中所属class_id=1的学生信息一并删除,这就涉及到了外键的约束。...只有在student中不存在id=1的学生,才能删除。 这就叫做外键约束。外键的本质就是产生关联,增加约束,保证表和表之间的完整性。

    22650

    【MYSQL】表的约束

    '学号', name varchar(5) ); 创建好表之后,我们可以追加主键 2.删除主键 alter table 表名 drop primary key; 案例: 3.复合主键 在创建表的时候...这样可以使对应于表的SQL语句执行得更快,可快速访问数据库表中的特定信息 七、唯一键 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...int auto_increment primary key, name varchar(5) unique ); 八、外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或...当定义外键后,要求外键列数据必须在主表的主键列存在或为null 关键词:foreign key (字段名) references 主表(列) 案例: 我们可以看到,学生信息是和班级表有关系的:某个班还有学生的时候我们不能直接删除这个班的数据

    25340

    MySQL:表的约束

    表的约束和约束的目标 表的约束:表中一定要有各种约束,通过约束,让我们未来插入数据库中的数据是符合预期的。约束本质是通过技术手段,倒逼程序员,插入正确的数据。...默认值default 默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性的使用默认值。...主键 6.1 建表时定义主键 primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。...外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。...这样插入一个并不属于class表的班级编号的时候,就会报错。 并且如果从表中对应的还有数据,是不能在主表中删除的。

    6710

    【MySQL】表的约束

    表的约束 表的约束:表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束本质是通过技术手段,倒逼用户,插入正确的数据。...table 表名 drop primary key; 例如删除上表的主键: 当表创建好以后但是没有主键的时候,可以再次追加主键: alter table 表名 add primary key(字段列表...在创建表的时候,在所有字段之后,使用 primary key (主键字段列表)来创建主键,如果有多个字段作为主键,可以使用复合主键。...数据库使用索引以找到特定值,然后顺指针找到包含该值的行。这样可以使对应于表的 SQL 语句执行得更快,可快速访问数据库表中的特定信息。 我们会在后面详细讲索引的概念。...;除此之外,如果我们删除了 class_id 为 20 的班级,也是不会报错的,因为它们之间没有约束关系,这也会导致我们可能删除了一个还有学生的班级!

    15510

    【MySql】表的约束

    表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性的使用默认值。...在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段作为主键,可以使用复合主键。...外键foreign key 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。...此时,在实际使用的时候,可能会出现什么问题? 有没有可能插入的学生信息中有具体的班级,但是该班级却没有在班级表中?

    21530

    SQL 基础(二)数据表的创建、约束、修改、查看、删除

    数据表删除 Management Studio 删除表 SQL 指令删除表 数据类型 数据类型 含义 CHARACTER(n) 字符/字符串。...,限定某字段只能录入允许范围内的值,既可表约束又可列约束 注意: 一个基本表中可定义多个 CHECK 一个字段仅能定义一个 CHECK 多个字段定义的 CHECK 必须为表约束 列约束 -- CHECK...、减少列宽 仅能修改 NOT NULL 、NULL 约束,其他约束需要通过“删除后重新添加“的方式完成修改 -- ALTER ALTER TABLE S ALTER COLUMN SN nvarchar...(12) DROP 仅用于删除完整性约束定义 -- DROP ALTER TABLE s3 DROP CONSTRAINT s_prim 数据表查看 右键 表 ,属性 查看表信息 数据表删除 Management...Studio 删除表 表存在依赖对象时,不可删除 SQL 指令删除表 仅可删除匹配用户建立的表,用户权限要对应 -- 删除基本表 DROP TABLE s

    1.1K20

    MySQL之表的约束

    一 介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性 主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FOREIGN...字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值 sex enum('male','female') not null default 'male' age int...,被约束的字段必须同时被key约束 #不指定id,则自动增长 create table student( id int primary key auto_increment, name varchar(...,在用delete删除后,再插入值,该字段仍按照删除前的位置继续增长 mysql> delete from student; Query OK, 4 rows affected (0.00 sec)...比起delete一条一条地删除记录,truncate是直接清空表,在删除大表时用它 mysql> truncate student; Query OK, 0 rows affected (0.01 sec

    4.9K60

    初谈表的约束

    概念 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。...表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primarykey,auto_increment,unique key 表中一定要有各种约束...,通过约束让我们未来插入数据库表中的数据是符合预期的。...默认值 默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性的使用默认值。...主键 主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。不意味着一个表中的主键只能添加给一列,于是有了复合主键。

    7310

    可以使用通配符的20个Excel工作表函数

    Excel提供了近20个支持在参数中使用通配符的工作表函数,本文将对这些函数进行介绍,更详细的信息可以参考Microsoft关于这些函数的帮助文档。 下面是在这些函数中可用于筛选字符的通配符: ?...下面是支持在参数中使用通配符的Excel函数: AVERAGEIF 返回区域内满足一个条件的所有单元格的平均值(算术平均值)。 AVERAGEIFS 返回满足一组或多组条件的所有单元格的平均值。...DVARP 通过使用列表或数据库中与指定的条件匹配的记录字段(列)中的数字,计算基于整个总体的总体方差。 HLOOKUP 在表或值数组的顶行中搜索值,然后在表或数组中指定的行返回同一列中的值。...当比较值位于数据表顶部行中,并且想要向下查看指定数量的行时,使用HLOOKUP。当比较值位于要查找的数据左侧列中时,使用VLOOKUP。...VLOOKUP 在表最左边的列中查找值,然后从指定的列中返回同一行中的值。 注:以上内容整理自exceluser.com,供学习参考。

    3.3K20

    【MySQL】008-表的约束

    : ""与NULL是不同的两个概念; 说明链接:https://blog.csdn.net/u014743697/article/details/54136092 2、删除name的非空约束,本质上就是更改表的字段...: -- 删除name的非空约束 ALTER TABLE stu MODIFY NAME VARCHAR(20); 3、创建表完成之后添加约束,本质上也是更改表的字段: -- 创建表之后,添加name的非空约束...-- 主键约束 NAME VARCHAR(20) ); 3、删除主键约束和创建表之后添加主键约束与非空约束和唯一约束一样 五、主键约束——自动增长 1、概念 如果某一列是数值类型的,使用auto_increment...) ); 注意:添加语句时主键的内容填入NULL即可,会根据上一个主键的值进行自动增加 3、删除自动增长和创建表后自动增长,同非空约束和唯一约束; 六、外键约束 1、描述 个人理解:加入一个部门的员工表...创建并添加数据记录,主表才能使用; 完整案例代码: -- 创建从表,记录学生的性别和年龄,id自增长 CREATE TABLE stu_p( id INT PRIMARY KEY AUTO_INCREMENT

    6810

    MySQL 临时表的建立及删除临时表的使用方式

    MySQL 临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。...临时表在MySQL 3.23版本中添加,如果你的MySQL版本低于 3.23版本就无法使用MySQL的临时表。不过现在一般很少有再使用这么低版本的MySQL数据库服务了。...实例 以下展示了使用MySQL 临时表的简单实例,以下的SQL代码可以适用于PHP脚本的mysql_query()函数。...如果你退出当前MySQL会话,再使用 SELECT命令来读取原先创建的临时表数据,那你会发现数据库中没有该表的存在,因为在你退出时该临时表已经被销毁了。...---- 删除MySQL 临时表 默认情况下,当你断开与数据库的连接后,临时表就会自动被销毁。当然你也可以在当前MySQL会话使用 DROP TABLE 命令来手动删除临时表。

    10.8K11

    Linux通配符的使用详解

    由命令行环境中,我们不能直观地看到一些文件或目录的名称及其他一些信息,这时候通配符就派上用场啦!当不知道真正字符或懒得输入完整文件或目录名称时,使用通配符代替一个或多个真正的字符就十分方便啦!...^ 若中括号内的第一个字符为指数符号(^),那表示取反,例如^abc表示除了a,b,c之外一定有一个字符 {str1,str2,…} 匹配sr1或str2(或更多)其一字符串 二、使用示例 星号(*)...- 1 wildcard wildcard 0 2月 4 20:55 ab.txt -rw-r--r-- 1 wildcard wildcard 0 2月 4 20:55 acd.txt 通过通配符...,这里搭配了*使用。...很多命令都可以使用通配符,比较常见的有ls,dir,vdir,cp,mv,scp,rm,rmdir等。

    1.8K30

    MySQL数据库——表的约束(非空约束、唯一约束、主键约束、外键约束)

    目录 1 表的约束 约束,是对表中的数据进行限定,保证数据的正确性、有效性和完整性,约束分为以下几类: 主键约束:primary key 非空约束:not null 唯一约束:unique 外键约束:foreign...); 2)创建表后再添加非空约束: ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;  3)删除name的非空约束: ALTER TABLE stu MODIFY...UNIQUE ); 注意:MySQL中唯一约束限定的列的值可以有多个null 2)删除唯一约束: -- alter table stu modify number varchar(20); 不同于非空约束的删除方法...以上仍然存在一个问题,当在员工表中输入不存的部门时,数据依然可以添加,不符合实际,因此,这里就可以通过使用外键约束来解决。 【概念】什么是外键约束?...外键,就是从表中与主表主键对应的那一列,如:员工表中的dep_id,其中,主表是一方,用来约束别人的表,从表可以是多方,被别人约束的表。 注意:外键可以为NULL,但是不能是不存在的外键值。 ?

    14.6K21

    MySQL表的完整性约束

    概览   为了防止不符合规范的数据进入数据库,在用户对数据进行插入、修改、删除等操作时,DBMS自动按照一定的约束条件对数据进行监测,使不符合规范的数据不能进入数据库,以确保数据库中存储的数据正确、有效...约束条件与数据类型的宽度一样,都是可选参数,主要分为以下几种: # NOT NULL :非空约束,指定某列不能为空; # UNIQUE : 唯一约束,指定某列或者几列组合不能重复 # PRIMARY...AUTO_INCREMENT 约束字段为自动增长,被约束的字段必须同时被key约束 ? ?...比起delete一条一条地删除记录,truncate是直接清空表,在删除大表时用它 mysql> truncate student; Query OK, 0 rows affected (0.01 sec...Restrict方式 同no action, 都是立即检查外键约束 . Set default方式 父表有变更时,子表将外键列设置成一个默认的值 但Innodb不能识别

    3.5K20

    MYSQL数据库-表的约束

    零、前言 本章主要讲解学习MYSQl数据库中的表的约束 表的约束 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性...“约束” 2、默认值 默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性的使用默认值 默认值的生效:数据在插入的时候不给该字段赋值,就使用默认值...字段列表) 删除主键: alter table 表名 drop primary key; 复合主键: 在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段作为主键...索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序 数据库使用索引以找到特定值,然后顺指针找到包含该值的行。...,不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有,在实际使用的时候,可能会出现有没有可能插入的学生信息中有具体的班级,但是该班级却没有在班级表中,这很明显是有问题的 因为此时两张表在业务上是有相关性的

    7.5K30

    MySQL数据库:表的约束

    表的约束,实质上就是用数据类型去约束字段,但是数据类型的约束手法很单一,比如,我们在设置身份证号这个字段,数据类型唯一起的约束是它属于char类型或者varchar类型,不能是浮点型也不能是日期时间类型...约束为null时,不插入数据会默认为NULL。 默认值 默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性的使用默认值。...:数据在插入的时候不给该字段赋值,就使用默认值。...,再追加主键 alter table 表名 add primary key(字段列表) 删除主键 alter table 表名 drop primary key; 举例: 原本上面的表tt15中,id为主键...,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。

    28230

    oracle常用基础命令创建表多字段组合主键约束查看表的主键名称 注意大写禁用开启主键约束删除约束等效上面

    使用系统用户登录 [username/password][@server][as sysdba|sysoper] 查看登录的用户 show user 启用scott用户 alter user scott...file_name from dba_data_files where tablespace_name='$tablespace_name'; # 临时表空间的路径 select file_name...注意不能删除第一个否则全部删掉 alter tablespace $tablespace_name drop datafile '$filepath' size $sizeM; 删除表空间 # 仅仅删除表空间...删除表数据 truncate table $table_name # 删除数据表 drop table $table_name a 插入数据 insert into (id,username,regdate...userinfo disable|enable contraint pk_userinfo_id_username; 删除约束 alter table userinfo drop contraint pk_name

    1.4K50
    领券