我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

mysql中怎么实现主键自动增长

本篇文章为大家展示了MySQL中怎么实现主键自动增长,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

成都创新互联公司从2013年创立,先为亳州等服务建站,亳州等地企业,进行企业商务咨询服务。为亳州企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

1、我们先建一个表user

mysql> create table user(
    -> id int(4) primary key auto_increment,
    -> username varchar(20),
    -> password varchar(20));
Query OK, 0 rows affected (0.08 sec)

2、我们先插入一条数据:

mysql> insert into user values (null,'admin',300000);
Query OK, 1 row affected (0.09 sec)

3、我们插入的主键值为null,可还是插入成功了。查看该表的值:

mysql> select * from user;
+----+----------+----------+
| id | username | password |
+----+----------+----------+
|  1 | admin    | 300000   |
+----+----------+----------+
1 row in set (0.00 sec)

该表中的id仍为1。

4、我们再插一条正常的数据:

mysql> insert into user (username,password) values ('Europa','123');
Query OK, 1 row affected (0.03 sec)

5、自动增长后是2,数据库中呢?我们看下:

mysql> select * from user;
+----+----------+----------+
| id | username | password |
+----+----------+----------+
|  1 | admin    | 300000   |
|  2 | Europa   | 123      |
+----+----------+----------+
2 rows in set (0.00 sec)

数据库中的值就是2

6、我们再插入一条手动指定主键值的数据:

mysql> insert into user values (4,'europa','123');
Query OK, 1 row affected (0.24 sec)

7、若按自动增长,即为3的。我们看下数据库里的值:

mysql> select * from user;
+----+----------+----------+
| id | username | password |
+----+----------+----------+
|  1 | admin    | 300000   |
|  2 | Europa   | 123      |
|  4 | europa   | 123      |
+----+----------+----------+
3 rows in set (0.00 sec)

并非我们猜想的值,是手动设定的值4。

你可以继续进行试验,但你最终会发现,若自动增长的主键值,你手动设为null,数据库会忽略掉null,按自动增长给值;若手动给其他合法的值,

就不会自动增长,按你给定的值给值。

因此可以得出结论:mysql中的主键自动增长时,他会先检查插入的主键值是否合法,若不合法就报错;再者检验插入的主键值是否为空,若为空,则

按自动增长赋值;再者,在插入数据时没有给主键设值,也会自动增长赋值。

上述内容就是mysql中怎么实现主键自动增长,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


分享名称:mysql中怎么实现主键自动增长
转载来于:http://mswzjz.cn/article/joeped.html

其他资讯