mysql--约束条件
- 主键的测试 PRIMARY KEY(PRIMARY可以省略)
--查看创建表的标的定义,可以查看主键
SHOW CREATE TABLE user1; INSERT user1 VALUES(1,'king');--主键不能重复
INSERT user1 VALUES(13,'king'); --复合主键
CREATE TABLE IF NOT EXISTS user2(
id INT,
username VARCHAR(20),
card CHAR(18),
PRIMARY KEY(id,card)--复合主键,这是一个主键
);
- 自增长的测试(让编号自动化)
CREATE TABLE IF NOT EXISTS user3(
id SMALLINT KEY AUTO_INCREMENT,
username VARCHAR(20)
)AUTO_INCREMENT=100;--这是指定自增长的值 查看自增长的值
SHOW CREATE TABLE user3;
user3 | CREATE TABLE `user3` (
`id` smallint(6) NOT NULL AUTO_INCREMENT,
`username` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=114 DEFAULT CHARSET=utf8 | INSERT user3 VALUES(1,'king');--第一次指定值,id是自增长的
INSERT user3(username) VALUES('queue');--只是插入username的值,手动指定的,id的值是自增长的值,就是已经有的编号加1
INSERT user3 VALUES(111,'queue');
INSERT user3(username) VALUES('queue');
INSERT user3 VALUES(DEFAULT,'queue'); ysql> SELECT * FROM user3;
+-----+----------+
| id | username |
+-----+----------+
| 1 | king |
| 2 | queue |
| 111 | queue |
| 112 | queue |
| 113 | queue |
+-----+----------+ 修改自增长的值
ALTER TABLE user3 AUTO_INCREMENT=500 给自增长赋值
- 非空约束的测试(非空的字段在插入的时候不能有null,标志位非空的时候插入的时候必须给值,不然会报错)
--测试NOT NULL 非空一般是搭配默认值来玩的
CREATE TABLE IF NOT EXISTS user4(
id INT UNSIGNED KEY AUTO_INCREMENT,--这里 无符号的键值 非空
userName VARCHAR(20) NOT NULL,
password CHAR(20) NOT NULL,
age TINYINT UNSIGNED
); INSERT user4(username,password) VALUES('king','king');
INSERT user4(username,password,age) VALUES('king','king',12);
INSERT user4(username,password) VALUES('NULL','NULL'); mysql> SELECT * FROM user4;
+----+----------+----------+------+
| id | userName | password | age |
+----+----------+----------+------+
| 1 | king | king | NULL |
| 2 | king | king | 12 |
| 3 | NULL | NULL | NULL |
+----+----------+----------+------+
- 测试默认值 DEFAULT(默认值)与NOT NULL配合使用
--测试默认值
CREATE TABLE IF NOT EXISTS user5(
id INT UNSIGNED KEY AUTO_INCREMENT,
userName VARCHAR(20) NOT NULL,
password CHAR(20) NOT NULL,
age TINYINT UNSIGNED DEFAULT 18,--DEFAULT +数据 添加默认值 和NOT NULL搭配使用
addr VARCHAR(50) NOT NULL DEFAULT '北京',
sex ENUM('男','女','保密') NOT NULL DEFAULT '男'
); mysql> DESC user5;
+----------+----------------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+----------------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| userName | varchar(20) | NO | | NULL | |
| password | char(20) | NO | | NULL | |
| age | tinyint(3) unsigned | YES | | 18 | |
| addr | varchar(50) | NO | | 北京 | |
| sex | enum('男','女','保密') | NO | | 男 | |
+----------+----------------------------+------+-----+---------+----------------+ INSERT user5(userName,password) VALUES('king','king');
INSERT user5 VALUES(2,'fuzhiqiang','dazhi',29,'上海','保密');
INSERT user5 VALUES(3,'fuzhiqiang','dazhi',DEFAULT,DEFAULT,'保密');--利用关键字DEFAULT进行默认值的插入 mysql> SELECT * FROM user5;
+----+------------+----------+------+--------+--------+
| id | userName | password | age | addr | sex |
+----+------------+----------+------+--------+--------+
| 1 | king | king | 18 | 北京 | 男 |
| 2 | fuzhiqiang | dazhi | 29 | 上海 | 保密 |
| 3 | fuzhiqiang | dazhi | 18 | 北京 | 保密 |
+----+------------+----------+------+--------+--------+
- 测试唯一的约束性 (一个表中只有一个主键,可以有多个唯一,但是唯一的不允许重复) UNIQUE KEY(KEY可以省略)
CREATE TABLE IF NOT EXISTS user6(
id TINYINT UNSIGNED KEY AUTO_INCREMENT,
username VARCHAR(20) NOT NULL,
card CHAR(18) UNIQUE--唯一性
); mysql> DESC user6;
+----------+---------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+---------------------+------+-----+---------+----------------+
| id | tinyint(3) unsigned | NO | PRI | NULL | auto_increment |
| username | varchar(20) | NO | | NULL | |
| card | char(18) | YES | UNI | NULL | |
+----------+---------------------+------+-----+---------+----------------+ INSERT user6(username) VALUES('A1'); INSERT user6(username,card) VALUES('','A1'); INSERT user6(username,card) VALUES('','A1');--这个是错误的,因为card字段是唯一性的,不能插入相同的值 +----+----------+------+
| id | username | card |
+----+----------+------+
| 1 | A1 | NULL |
| 2 | A1 | NULL |
| 3 | 1111 | A1 |
+----+----------+------+
- 建表步骤
-
--建表的步骤
CREATE TABLE [IF NOT EXISTS] tbl_name(
--按照下面的顺序呢进行建表
字段名称 字段类型 [UNSIGNED|ZEROFILL] [NOT NULL|NULL] [DEFAULT 默认值] [[PRIMARY] KEY | UNIQUE [KEY]] [AUTO_INCREMENT]
--上面中 主键的PRIMARY可以省略, 唯一性约束的KEY可以省略,
)ENGINE=INNODB CHARSET=UTF8 AUTO_INCREMENT=100;--引擎:默认的是INNODB, 编码方式:默认的是utf8, 自增长量:可以在这里初始化
-
mysql--约束条件的更多相关文章
- mysql 约束条件目录
mysql 约束条件 mysql 约束条件 not null与default mysql 约束条件 unique key 唯一的键 mysql primary key 主键 mysql auto_in ...
- mysql 约束条件介绍
mysql 约束条件介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FO ...
- mysql 约束条件 auto_increment 自动增长目录
mysql 约束条件 auto_increment 自动增长 mysql 约束条件 auto_increment 自动增长起始值 布长 起始偏移量 mysql 约束条件 auto_increment ...
- mysql 约束条件 not null与default
not null与default 是否可空,null表示空,非字符串not null - 不可空null - 可空 use db4: 默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动 ...
- mysql 约束条件 unique key 唯一的键
如果不设置unique 会出现两条相同的记录 mysql)); Query OK, rows affected (0.01 sec) mysql ,,'mike'); Query OK, rows a ...
- mysql 约束条件 primary key 主键
primary key字段的值不为空且唯一 约束:not null unique 存储引擎:innodb 对于innodb来说,一张表内必须有一个主键 单列做主键多列做主键(复合主键) 通常都是id字 ...
- mysql 约束条件 auto_increment 自动增长起始值 布长 起始偏移量
我们指定一个字段为自动增长,他默认从1开始自动增长,默认值为1,每次增长为1,步长为1 模糊查询 like % 代表任意个数字符 任意字符长度 查看mysql正在使用变量 show variables ...
- mysql 约束条件 auto_increment 自动增长
约束字段为自动增长,被约束的字段必须同时被key约束 id自动增长,每插入一条记录,自动增长 创建一张表 t20 id 字段设置为 不为空 唯一 自动增长 mysql)); Query OK, row ...
- mysql 约束条件 auto_increment 自动增长 清空表 自动增长情况
清空表情况: mysql> delete from t20; Query OK, rows affected (0.00 sec) mysql> show create table t20 ...
- mysql 约束条件 auto_increment 自动增长 创建表时设置自增字段
auto_increment mysql) )auto_increment; Query OK, rows affected (0.01 sec) mysql> show create tabl ...
随机推荐
- scrapy入门实践1
Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中. 这就是整个Scrapy的架构图了: 各部件职能: Scrapy ...
- Maven里头的pom.xml配置详解
正常的pom配置文件如下所示: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http ...
- python之 centos6.7下 python 3.5.2 源码、Django-1.9 安装
在linux6.5中已经自带了python 2 .python 2.6 ,并且yum程序使用的就是自带的python,所以系统自带的python不要随意卸载否则可能导致yum用不了. 测试环境:cen ...
- loj 6485 LJJ学二项式定理 —— 单位根反演
题目:https://loj.ac/problem/6485 先把 \( a_{i mod 4} \) 处理掉,其实就是 \( \sum\limits_{i=0}^{3} a_{i} \sum\lim ...
- dockerfile http_php
FROM centos6.6-php5.5:0.0.1 MAINTAINER syberos:wangmo RUN mv /etc/php.ini /etc/php.ini.bak COPY ./ph ...
- apache配置详解 apache安装路径
http://www.linuxidc.com/Linux/2015-02/113921.htm 不同apache的安装方式 的安装目录示例 http://www.121down.com/articl ...
- Azure的CentOS上安装LIS (Linux Integration Service)
Azure上虚拟化技术都是采用的Hyper-v,每台Linux虚拟机都安装了LIS(Linux Integration Service).LIS的功能是为VM提供各种虚拟设备的驱动.所以LIS直接影响 ...
- 蓝桥杯 基础练习 BASIC-23 芯片测试
基础练习 芯片测试 时间限制:1.0s 内存限制:512.0MB 问题描述 有n(2≤n≤20)块芯片,有好有坏,已知好芯片比坏芯片多. 每个芯片都能用来测试其他芯片.用好芯片测试其他芯片时, ...
- 2018年长沙理工大学第十三届程序设计竞赛 J杯子
链接:https://www.nowcoder.com/acm/contest/96/J来源:牛客网 杯子 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言655 ...
- 开发环境入门 linux基础(部分)虚拟内存,rpm和yum安装
虚拟内存,rpm和yum安装 文本中查找 /内容 替换:扩展模式下(:)%s /替换目标/要替换的文件/ (只替换第一个)(后边加g全部替换) :set u添加行号 raid lvm逻辑卷 df - ...