mysql 列约束
mysql可以对插入的数据进行特定得验证,只有满足条件才可以插入到数据表中,否则认为是非法插入;
例如:人性别只可以是男、女。年龄只能是0-100。
①主键约束查重-PRIMARY KEY,1表一个;
例子:id INT PARIMARY KEY,
声明主键约束列上的值不能出现重复,一个表只可以有一个主键,设置主键约束不可以使用NULL值;
表中查询的记录会按照主键由小到大的顺序排列--加快查找速度
②非空约束-NOT NULL,批量插入会失效
注意问题:INSERT INTO 插入时候会收到影响,起不了作用;
例子:id INT NOT NULL,
在插入数据时候,无法确定要保存的数据,例如:无法确定员工的工资,生日都可以使用NULL;
③唯一约束-UNIQUE
声明了唯一约束的列上不能插入重复的值,允许插入NULL,甚至多个NULL.
说明:NULL这个值比较特殊,它和任何值都不相等,甚至和自身都不相等;
注意:一个表里可以有多个唯一约束UNIQUE,但是只能有一个主键约束 PRIMARY KEY
④检查约束-CHECK
检查约束可以对插入的数据进行自定义的验证
CREATE TABLE student(score TINYINT CHECK(score>=0&scure<=100)
);
mysql 中不支持检查约束,会降低数据的插入速度;
⑤默认值约束-DEFAULT
可以使用DEFAULT关键字声明默认值,有两种方式应用默认值
第一种设置DEFAULT方法
CREATE TABLE family(
fid INT PRIMARY KEY,
fname VARCHAR(20) UNIQUE,
XX XX DEFAULT 1
);
INSERT INTO family VALUES(50,'华硕',DEFAULT);
第二种设置DEFAULT方法
INSERT INTO family (fid,fname)VALUES(50,'华硕');第三个值自动使用默认数值
注意事项:不可以在表格后括号里加引号!!!
⑥外键约束-FOREIGN KEY
使用方法:
CREATE TABLE laptop(
lid INT PRIMARY KEY,
familyld INT,
FOREIGN KEY(familyId) REFERENCES laptop_family(fid)
);
注意问题:
1.必须是另一个表格的主键
2.列类型必须和另一个表格的一样
3.需要加了逗号写到下一行
声明了外键约束的列,取值必须在另一个表的主键列上出现过,两者的列类型要保持一致,允许使用多个NULL或者多个NULL
使用方法:
FOREIGN KEY (列名) REFERENCES 数据表(主键列)
mysql 中的自增列
AUTO_INCREMENT:
自动增长,假如一个列声明了自增列,无需手动赋值,直接赋值为NULL,会获取当前的最大值, 然后加1插入
注意: 1.只适用于整数型的主键列上面
2.自增列允许手动赋值
3.手动赋值后中间跳跃有缺失,还会按最大值继续增长。
4.使用方便,可以直接给上面写NULL,数字自动加1;
列约束汇总

mysql 列约束的更多相关文章
- mysql列约束
列属性(约束)1: 是否允许为空(not null) --not null不允许为空create table t_1( a tinyint(3) zerofill not null, b ...
- MySQL的列约束
1.列约束 (1)主键约束——PRIMARY KEY (2)非空约束——NOT NULL 声明了非空约束的列上,不允许使用NULL (3)唯一约束——UNIQUE 声明了唯一约束的列上不能插入重复的值 ...
- MySQL服务 - MySQL列类型、SQL模式、数据字典
MySQL列类型的作用: 列类型可以简单理解为用来对用户往列种存储数据时做某种范围"限定",它可以定义数据的有效值(字符.数字等).所能占据的最大存储空间.字符长度(定长或变长). ...
- MYSQL中约束及修改数据表
MYSQL中约束及修改数据表 28:约束约束保证数据的完整性和一致性约束分为表级约束和列级约束约束类型包括: NOT NULL(非空约束) PRIMARY KEY(主键约束) UNI ...
- 数据库-SQL语句:删除和修改语句-列类型-列约束
使用MySQL客户端连接服务器的两种方式: (1)交互模式: ——查 mysql.exe -h127.0.0.1 -uroot -p mysql -uroot (2)脚本模式:——增删改 m ...
- mysql列的处理
MySQL 添加列,修改列,删除列 示例:ALTER TABLE tb_financial MODIFY CREATE_TIME DATETIME(3) DEFAULT NULL COMMENT '录 ...
- 【MySQL】MySQL的约束
在开始之前,笔者介绍一下笔者使用的数据库版本为5.7.所有的关系型数据库都支持对数据表使用约束,通过约束可以更好的保证数据表里数据的完整性.约束是在表上强制执行的数据校验,约束主要用于保证数据库里数据 ...
- mysql的约束
SQL 约束 约束用于限制加入表的数据的类型. 可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后也可以(通过 ALTER TABLE 语句). (1)NOT NULL约 ...
- [转]mysql的约束
转自:http://blog.csdn.net/kqygww/article/details/8882990 MySQL中约束保存在information_schema数据库的table_constr ...
- MYSQL数据库约束类型
07.14自我总结 MYSQL数据库约束类型 一.主键约束(primary key) 主键约束要求主键列的数据唯一,并且不能为空.主键分为两种类型:单字段主键和多字段联合主键. 1.单字段主键 写法 ...
随机推荐
- C# String.IsNullOrEmpty()方法的使用
IsNullOrEmpty(string)是String类的一个有参的方法,方法需要类的调用,所以String.IsNullOrEmpty(string) IsNullOrEmpty是判断字符串的Nu ...
- js数组去重,id相同对某值相加合并
js数组去重,id相同对某值相加合并 案例1: 假设需要处理的数组结构. let arr =[ {id:'1', value:10}, {id:'1', value:20}, {id:'2', val ...
- 十九、Service Ingress
Service Ingress Ingress-Nginx github 地址:https://github.com/kubernetes/ingress-nginx Ingress-Nginx 官方 ...
- JavaSPI详解
目录 一个问题 什么是SPI API 与 SPI 一个简单的例子 SPI机制的实现 Java SPI的问题 为什么SPI机制打破了双亲委派模型 参考资料 一个问题 在项目开发中,经常会使用到数据库驱动 ...
- Nginx实用配置-2
Nginx配置-2 1.升级Openssl [root@rocky8 ~]# nginx -V #查看现在nginx的OpenSSL版本和编译情况 nginx version: nginx/1.22. ...
- 初识vue3.0
vue3.0 源码组织方式的变化 采用ts重写 独立的功能模块提取到单独的包中 90%的api兼容Vue2.x Composition API 组合api 解决vue2.x options api 开 ...
- 「工具推荐」golang 代码可视化工具 go-callvis
「工具推荐」go-callvis go-callvis是相对 以图片的形式展示了go程序的调用关系,这个工具在看复杂项目时尤其有用. 亲测,借助它看祖传golang代码,头痛好多了. 安装 go ge ...
- codeforces补题计划
11.15 Codeforces Round #833 (Div. 2) 知识点: D:高位和对低位无影响 E:笛卡尔树上dp 补题传送门
- 为什么Linux需要虚拟内存 [转载好文]
操作系统中的 CPU 和主内存(Main memory)都是稀缺资源,所有运行在当前操作系统的进程会共享系统中的 CPU 和内存资源,操作系统会使用 CPU 调度器分配 CPU 时间1并引入虚拟内存系 ...
- 交叉编译:zlib,openSSL,openSSH
1. 编译zlib wget https://www.zlib.net/zlib-1.2.12.tar.gz # 编译命令 export CC=arm-fullhanv3-linux-uclibcgn ...