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

mysql常见的选项和约束

约束主要是防止非法数据进入中,保证数据的正确性和一致性,统称为数据完整性 约束也可以防止一个被删除 MySQL约束保存在information_schema.table_constraints中...,可以通过该查询约束信息 常见的约束类型 not null非空,指定某列不为空(注意区分空和空格的关系) unique:唯一约束,指定某列和几列组合的数据不能重复 primary key:主键约束,指定某列的数据不能重复...保证一个或两个之间的参照完整性,外键是构建于一个的两个字段或者是两个的两个字段之间的参照关系 注意: 具有外键约束的列的值不能随便给,必须满足外键所引用的主键的取值 一张中可以定义多个外键 外键列默认可以给...MySQl中可以使用check约束,但是check约束对数据验证没有任何作用。...Oracle中国可以使用check约束,有相应作用 mysql> create table test_ck( -> id int check(id>0) -> ); mysql

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

MySql约束

中一定要有各种约束,通过约束,让我们未来插入数据库中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...into t13(name) values ('李四'); deault:如果设置了,用户将来插入,有具体的数据就用,没有就默认 如果我们没有明确指定一列要插入,用的是default,如果中,对应列默认没有设置...OK, 1 row affected (0.00 sec) 唯一键unique 一张中有往往有很多字段需要唯一性,数据不能重复,但是一张中只能有一个主键:唯一键就可以解决中有多个字段需要唯一性约束的问题...外键foreign key 外键用于定义主表和从之间的关系:外键约束主要定义在从上,主表则必须是有主键约束或unique约束。...建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。

17330

MySQL约束

反过来,在 mysql 角度,凡是插入进来的数据,都是符合数据约束的!约束的最终目的就是保证数据的完整性和可预期性。因此我们需要更多的约束条件!...通过 show 看看 t3 表语句: 可以看到 int(10),这个代表什么意思呢?整型不是 4 字节吗?这个 10 又代表什么呢?...七、唯一键 唯一键:unique;一张中有往往有很多字段需要唯一性,数据不能重复,但是一张中只能有一个主键;唯一键就可以解决中有多个字段需要唯一性约束的问题。...唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。 关于唯一键和主键的区别: 我们可以简单理解成,主键更多的是标识唯一性的。...建立外键的本质其实就是把相关性交给 mysql 去审核了,提前告诉 mysql 之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql 不允许你插入。

10410

MYSQL约束

五、主键 主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张中最多只能有一个主键;主键所在的列通常是整数类型。...这样可以使对应于的SQL语句执行得更快,可快速访问数据库中的特定信息 七、唯一键 一张中有往往有很多字段需要唯一性,数据不能重复,但是一张中只能有一个主键:唯一键就可以解决中有多个字段需要唯一性约束的问题...唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。 关于唯一键和主键的区别: 我们可以简单理解成,主键更多的是标识唯一性的。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...:外键约束主要定义在从上,主表则必须是有主键约束或unique约束

22040

MySQL约束

约束的本质: 通过技术手段倒逼程序员插入正确的数据。反过来站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。 约束的最终目标: 保证数据的完整性和可预期性。 为什么数据库这么严格?...二.的非空约束 1.NULL与’ '比较 在MySQL数据类型已经说过,这二者是不同的,NULL代表什么都没有,而' '代表一个空串。 在select语句中,NULL不会参与到相应的计算操作中。...三.默认值default 实际上就是缺省值,时设定之后,即便不对这个字段进行插入,其对应的值也会默认为default后面跟着的值。 插入default对应的字段后,就会将缺省值覆盖。...删除主键约束 这样,插入的数据就可以重复,但是通过观察,仍不能为空,因为not null在创建时的添加约束期间会一并添加到约束。不过有了主键,才能更好的查找数据,因为其具有唯一性。...对于主键的标识唯一性以及唯一键的业务唯一性的理解: 一个中若存在id,name,telephone三个字段,无疑id是要被标识唯一性主键的。

18450

通过sql命令 和 主外键约束以及其他约束

nvarchar(100) 5 ) 6 7 creat table emp 8 ( emp_id int constraint pk_emp_id_a primary key, --主键约束...emp_sex nchar(1), 11 dept_id int constraint fk_dept_id_b foreign key references dept(dept_id) --外键约束...创建的命令后面是小括号(),而不是{}, 2. 注释用-- 3....写完后,鼠标左键选中整个代码,分析、执行,最后生成 什么是约束constraint: 对一个中的属性操作的限制 分类: 主键约束:不允许重复元素,避免数据的冗余 外键约束:通过外键约束,从语法上保证了本事物所关联的其他事物一定是存在的...事物和事物之间的关系是通过外键来体现的 check约束:保证事物属性的取值在合法的范围之内 1 create table student 2 ( 3 stu_id int primary key

94820

MySQL&约束&事务

违反约束的不正确数据,将无法插入到中 常见的约束 约束约束关键字 主键 primary key 唯一 unique 非空 not null 外键 foreign key 主键约束 特点:不可重复...,对自增没有影响,使用truncate 是将整个删除掉,然后创建一个新的 自增的主键,重新从 1开始 非空约束 非空约束的特点: 某一列不予许为空 # 非空约束 CREATE TABLE emp2...); 唯一约束 唯一约束的特点: 中的某一列的值不能重复( 对null不做唯一的判断 ) CREATE TABLE emp3( eid INT PRIMARY KEY AUTO_INCREMENT,...ename VARCHAR(20) UNIQUE, sex CHAR(1) ); 主键约束与唯一约束的区别: 主键约束 唯一且不能够为空 唯一约束,唯一 但是可以为空 一个中只能有一个主键 , 但是可以有多个唯一约束...MySQL 事务隔离级别 一个数据库可能拥有多个访问客户端,这些客户端都可以并发方式访问数据库. 数据库的相同数据可能被多个事务同时访问,如果不采取隔离措施,就会导致各种问题, 破坏数据的完整性。

1.2K30

MySQL约束

一 介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性 主要分为: PRIMARY KEY (PK) 标识该字段为该的主键,可以唯一的标识记录 FOREIGN...---+ | egon | 18 | male | play,music | +------+-----+------+------------+ 三 unique ============设置唯一约束...nginx'); ERROR 1062 (23000): Duplicate entry '172.16.45.10-3306' for key 'PRIMARY' 五 auto_increment 约束字段为自动增长...,被约束的字段必须同时被key约束 #不指定id,则自动增长 create table student( id int primary key auto_increment, name varchar(...比起delete一条一条地删除记录,truncate是直接清空,在删除大时用它 mysql> truncate student; Query OK, 0 rows affected (0.01 sec

4.8K60

粗聊Mysql——你会么?

本文中说到的“”,并非单纯的一个库,或是一张,而是你建好的库和在项目的运营中,是否能应付各种事件,下面我说说几个我在项目中遇到的问题以及处理的方法,算是一个小小的心得,给大家分享下。...比如现在有2张,一张新闻栏目,一张新闻,现在两张需要进行关联,我想大多数人的做法肯定是在新闻表里一个新闻栏目id,然后把新闻栏目表里的主键ID(自增)写到这个字段里,通过这样进行两关联。   ...所以我建议两之间关联不用主键,而是单独一个编号的字段,我们这里可以用mysql的uuid()函数做为编号,相关文献可以参考《UUID做主键好还是不好》,只所以一张要2个主键,一个物理主键(自增id...至于性能,我本地测了下基本上没差异,网上也有人做了10W条数据的测试——《实测MYSQL UUID性能》。...所以我建议,既然定义为varchar,就代表不会涉及到计算,何不干脆定义一个通用的长度,比如varchar(50),如果真要限制长度,用程序去判断,不要让数据库来限制,不然用户输了一长串,结果mysql

5.2K10

mysql创建数据约束

MySQL中,是存储数据的基本单位,每张有若干列,每一行代表一条数据记录。在MySQL中,数据是按行存储的。...创建数据的基本语法如下 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] table_name( 列名1 数据类型 [约束条件] [默认值], 列名2 数据类型 [约束条件...] [默认值], ............. ) [约束条件]; 使用主键约束 主键由的一列或者多列组合而成。...主键约束要求主键列数据唯一,且不能为空。主键可以标识的唯一一条记录。的主键相当于的目录。为创建主键后,使用主键列作为查询条件可以大大加快的查询速度。...create table user_tmp4(id int, name varchar(20) not null); 使用默认约束 默认约束的作用是为某列指定默认值,在向中插入数据时,如果不指定该列的值

3.7K40

MYSQL数据库-约束

零、前言 本章主要讲解学习MYSQl数据库中的约束 约束 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性...这样可以使对应于的SQL语句执行得更快,可快速访问数据库中的特定信息 7、唯一键 一张中有往往有很多字段需要唯一性,数据不能重复,但是一张中只能有一个主键:唯一键就可以解决中有多个字段需要唯一性约束的问题...唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较 关于唯一键和主键的区别:主键更多的是标识唯一性的,而唯一键更多的是保证在业务上,不要和别的信息出现重复...示例: 8、外键 外键用于定义主表和从之间的关系:外键约束主要定义在从上,主表则必须是有主键约束或unique约束。...建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入

7.5K30

MySQL的完整性约束

约束条件与数据类型的宽度一样,都是可选参数,主要分为以下几种: # NOT NULL :非空约束,指定某列不能为空; # UNIQUE : 唯一约束,指定某列或者几列组合不能重复 # PRIMARY...| +---------+--------------+------+-----+---------+-------+ rows in set (0.01 sec) # 方法四:给已经建成的添加主键约束...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 系列教程之(五)DDL 操作:

创建RUNOOB数据库,并设定编码集为utf8 删除数据库 删库有风险,动手需谨慎 drop database 库名; MySQL 数据 创建MySQL数据需要以下信息: 名 表字段名 定义每个表字段...create table 名( 字段名 类型 [字段约束], 字段名 类型 [字段约束], 字段名 类型 [字段约束] ... ); 创建 通过 mysql> 命令窗口可以很简单的创建...MySQL数据。...查看表结构 desc stu; 查看表语句 show create table stu\G 修改结构 格式: alter table 名 action(更改选项); 添加字段: 添加字段:alter...name字段添加唯一性索引,索引名为uni_name; alter table user add unique uni_name(name); -- 为user中的email字段添加普通索引,索引名为

7.6K73

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

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

13.6K21
领券