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
0
投稿

猜你喜欢

  • Python实现输出某区间范围内全部素数的方法

    2022-04-25 10:04:50
  • Python获取"3年前的今天"的日期时间问题

    2022-02-01 12:12:13
  • Swoole webSocket客服IM消息系统方案解析

    2023-06-14 20:17:22
  • 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
  • 在 Windows 10 上安装 解压缩版 MySql(推荐)

    2024-01-21 18:18:24
  • Python 基于TCP 传输协议的网络通信实现方法

    2023-06-18 22:04:01
  • 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
  • 在Windows系统上搭建Nginx+Python+MySQL环境的教程

    2024-01-24 08:04:40
  • 用FrontPage制作缩略图和图片重叠效果

    2007-11-18 14:45:00
  • 使用python实现抓取中国银行外汇牌价首页数据实现

    2021-11-28 02:05:49
  • SQL查询效率-100w数据查询只要1秒

    2008-08-20 18:25:00
  • Pthon批量处理将pdb文件生成dssp文件

    2021-10-07 13:11:04
  • asp之家 网络编程 m.aspxhome.com