约束条件一

Null,Default

不允许为空,传值为空则默认写入male

mysql> create table t1(
    -> id int,
    -> name char(6),
    -> sex enum('male','female') not null default 'male'
    -> );

 查看表结构

mysql> desc t1;
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | char(6)               | YES  |     | NULL    |       |
| sex   | enum('male','female') | NO   |     | male    |       |
+-------+-----------------------+------+-----+---------+-------+

 性别传空值,默认设置成了male

mysql> insert into t1(id,name) values(1,'ya'); Query OK, 1 row affected (0.00 sec) mysql> select * from t1; +------+--------+------+ | id | name | sex | +------+--------+------+ | 1 | ya | male | +------+--------+------+ 1 row in set (0.00 sec)

 unique限制数据唯一性

单列唯一

方式一:

mysql> create table t2(
    -> id int,
    -> name char(10) unique);
Query OK, 0 rows affected (0.01 sec)

mysql> desc t2;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(11)  | YES  |     | NULL    |       |
| name  | char(10) | YES  | UNI | NULL    |       |
+-------+----------+------+-----+---------+-------+
2 rows in set (0.01 sec)

 方式二:

mysql> create table department( id int, name char(10), unique(name));
Query OK, 0 rows affected (0.01 sec)

mysql> desc department;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(11)  | YES  |     | NULL    |       |
| name  | char(10) | YES  | UNI | NULL    |       |
+-------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

 联合唯一

多列在一起保证唯一

mysql> create table services(
    -> id int,
    -> ip char(15),
    -> port int,
    -> unique(ip,port),
    -> unique(id));
mysql> desc services;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(11)  | YES  | UNI | NULL    |       |
| ip    | char(15) | YES  | MUL | NULL    |       |
| port  | int(11)  | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
3 rows in set (0.00 sec)

 同时插入多行数据

mysql> insert into services values (1,'192.168.10.1',80),(2,'192.168.10.1',81),(3,'192.168.10.2',80);
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select * from services;
+------+-----------------+------+
| id   | ip              | port |
+------+-----------------+------+
|    1 | 192.168.10.1    |   80 |
|    2 | 192.168.10.1    |   81 |
|    3 | 192.168.10.2    |   80 |
+------+-----------------+------+
3 rows in set (0.00 sec)

 插入多列不唯一时会报错

mysql> insert into services values (4,'192.168.10.1',80);
ERROR 1062 (23000): Duplicate entry '192.168.10.1   -80' for key 'ip'

 pirmary key

约束:不为空,且唯一

存储引擎:Innodb,一张表内必须有一个主键

show create table services\G
*************************** 1. row ***************************
       Table: services
Create Table: CREATE TABLE `services` (
  `id` int(11) DEFAULT NULL,
  `ip` char(15) DEFAULT NULL,
  `port` int(11) DEFAULT NULL,
  UNIQUE KEY `ip` (`ip`,`port`),
  UNIQUE KEY `id` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

 单列主键

mysql> create table t17(
    -> id int primary key,
    -> name char(16));
Query OK, 0 rows affected (0.01 sec)

mysql> desc t17;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(11)  | NO   | PRI | NULL    |       |
| name  | char(16) | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

 primary key重复

mysql> insert into t17 values(1,'huangya');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

 复合主键

mysql> create table t18(
    -> ip char(15),
    -> port int,
    -> primary key(ip,port));
Query OK, 0 rows affected (0.01 sec)

mysql> desc t18;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| ip    | char(15) | NO   | PRI | NULL    |       |
| port  | int(11)  | NO   | PRI | NULL    |       |
+-------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

 插入多列重复值报错

mysql> insert into t18 values('10.10.10.1',80),('10.10.10.1',80);
ERROR 1062 (23000): Duplicate entry '10.10.10.1     -80' for key 'PRIMARY'
mysql>

 auto_increment,自增长

mysql> create table t20(
    -> id int primary key auto_increment,
    -> name char(15)
    -> );

 

仅传入name字段即可,也可手动传入,只要保证不为空且唯一即可。

mysql> insert into t20(name) values('huang'),('yaya'),('m');
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select * from t20;
+----+-----------------+
| id | name            |
+----+-----------------+
|  1 | huang           |
|  2 | huang           |
|  3 | yaya            |
|  4 | m               |
+----+-----------------+
4 rows in set (0.00 sec)

 自增长默认从1开始增长,步长为1

mysql> show variables like 'auto_inc%';
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 1     |
| auto_increment_offset    | 1     |
+--------------------------+-------+
2 rows in set (0.00 sec)

mysql>

 手动调整布长

会话级别调整,仅本次会话有效

mysql> set session auto_increment_increment=5;
Query OK, 0 rows affected (0.00 sec)

 全局设置步长

mysql> set global auto_increment_increment=5;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like 'auto_inc%';
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 5     |
| auto_increment_offset    | 1     |
+--------------------------+-------+
2 rows in set (0.00 sec)

起始偏移量设置,一定要小于等于步长,否则设置失效。

mysql> set session auto_increment_offset=2;
Query OK, 0 rows affected (0.00 sec)

mysql> set global auto_increment_offset=2;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like 'auto_inc%';
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 5     |
| auto_increment_offset    | 2     |
+--------------------------+-------+
2 rows in set (0.01 sec)
posted @ 2018-05-20 10:32  丫丫625202  阅读(225)  评论(0编辑  收藏  举报