MySQL 序列 AUTO_INCREMENT详解及实例代码
作者:lqh 时间:2024-01-20 17:04:37
MySQL 序列 AUTO_INCREMENT详解及实例代码
MySQL序列是一组整数:1, 2, 3, ...,由于一张数据表只能有一个字段自增主键, 如果你想实现其他字段也实现自动增加,就可以使用MySQL序列来实现。
本章我们将介绍如何使用MySQL的序列。
使用AUTO_INCREMENT
MySQL中最简单使用序列的方法就是使用 MySQL AUTO_INCREMENT 来定义列。
实例
以下实例中创建了数据表insect, insect中id无需指定值可实现自动增长。
mysql> CREATE TABLE insect
-> (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
-> PRIMARY KEY (id),
-> name VARCHAR(30) NOT NULL, # type of insect
-> date DATE NOT NULL, # date collected
-> origin VARCHAR(30) NOT NULL # where collected
);
Query OK, 0 rows affected (0.02 sec)
mysql> INSERT INTO insect (id,name,date,origin) VALUES
-> (NULL,'housefly','2001-09-10','kitchen'),
-> (NULL,'millipede','2001-09-10','driveway'),
-> (NULL,'grasshopper','2001-09-10','front yard');
Query OK, 3 rows affected (0.02 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> SELECT * FROM insect ORDER BY id;
+----+-------------+------------+------------+
| id | name | date | origin |
+----+-------------+------------+------------+
| 1 | housefly | 2001-09-10 | kitchen |
| 2 | millipede | 2001-09-10 | driveway |
| 3 | grasshopper | 2001-09-10 | front yard |
+----+-------------+------------+------------+
3 rows in set (0.00 sec)
获取AUTO_INCREMENT值
在MySQL的客户端中你可以使用 SQL中的LAST_INSERT_ID( ) 函数来获取最后的插入表中的自增列的值。
在PHP或PERL脚本中也提供了相应的函数来获取最后的插入表中的自增列的值。
PERL实例
使用 mysql_insertid 属性来获取 AUTO_INCREMENT 的值。 实例如下:
$dbh->do ("INSERT INTO insect (name,date,origin)
VALUES('moth','2001-09-14','windowsill')");
my $seq = $dbh->{mysql_insertid};
PHP实例
PHP 通过 mysql_insert_id ()函数来获取执行的插入SQL语句中 AUTO_INCREMENT列的值。
mysql_query ("INSERT INTO insect (name,date,origin)
VALUES('moth','2001-09-14','windowsill')", $conn_id);
$seq = mysql_insert_id ($conn_id);
重置序列
如果你删除了数据表中的多条记录,并希望对剩下数据的AUTO_INCREMENT列进行重新排列,那么你可以通过删除自增的列,然后重新添加来实现。 不过该操作要非常小心,如果在删除的同时又有新记录添加,有可能会出现数据混乱。操作如下所示:
mysql> ALTER TABLE insect DROP id;
mysql> ALTER TABLE insect
-> ADD id INT UNSIGNED NOT NULL AUTO_INCREMENT FIRST,
-> ADD PRIMARY KEY (id);
设置序列的开始值
一般情况下序列的开始值为1,但如果你需要指定一个开始值100,那我们可以通过以下语句来实现:
mysql> CREATE TABLE insect
-> (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT = 100,
-> PRIMARY KEY (id),
-> name VARCHAR(30) NOT NULL, # type of insect
-> date DATE NOT NULL, # date collected
-> origin VARCHAR(30) NOT NULL # where collected
);
或者你也可以在表创建成功后,通过以下语句来实现:
mysql> ALTER TABLE t AUTO_INCREMENT = 100;
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
标签:MySQL,序列,AUTO,INCREMENT
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Python实现输出某区间范围内全部素数的方法
2022-04-25 10:04:50
![](https://img.aspxhome.com/file/2023/8/68318_0s.png)
Python获取"3年前的今天"的日期时间问题
2022-02-01 12:12:13
Swoole webSocket客服IM消息系统方案解析
2023-06-14 20:17:22
![](https://img.aspxhome.com/file/2023/7/55507_0s.png)
ASP程序与SQL存储过程结合使用详解
2011-03-25 10:50:00
ORACLE数据库空间整理心得
2010-07-16 13:33:00
Go语言协程处理数据有哪些问题
2024-02-12 04:54:53
Pandas数据分析固定时间点和时间差
2022-03-05 20:24:07
![](https://img.aspxhome.com/file/2023/4/127894_0s.png)
在 Windows 10 上安装 解压缩版 MySql(推荐)
2024-01-21 18:18:24
![](https://img.aspxhome.com/file/2023/7/118467_0s.png)
Python 基于TCP 传输协议的网络通信实现方法
2023-06-18 22:04:01
![](https://img.aspxhome.com/file/2023/3/89233_0s.jpg)
Django 使用easy_thumbnails压缩上传的图片方法
2023-11-10 07:47:38
用Python编写一个每天都在系统下新建一个文件夹的脚本
2021-11-08 22:39:16
揭开HTML 5工作草稿的神秘面纱
2008-02-13 08:25:00
php之redis短线重连案例讲解
2023-06-12 13:16:04
实现div可编辑的常见方法
2007-11-06 12:02:00
十分钟利用Python制作属于你自己的个性logo
2021-08-25 05:12:41
![](https://img.aspxhome.com/file/2023/2/80762_0s.jpg)
在Windows系统上搭建Nginx+Python+MySQL环境的教程
2024-01-24 08:04:40
![](https://img.aspxhome.com/file/2023/5/90715_0s.jpg)
用FrontPage制作缩略图和图片重叠效果
2007-11-18 14:45:00
使用python实现抓取中国银行外汇牌价首页数据实现
2021-11-28 02:05:49
![](https://img.aspxhome.com/file/2023/9/128749_0s.jpg)
SQL查询效率-100w数据查询只要1秒
2008-08-20 18:25:00
Pthon批量处理将pdb文件生成dssp文件
2021-10-07 13:11:04