• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL 序列 AUTO_INCREMENT详解及实例代码

    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安装图解 mysql图文安装教程(详细说明)
    • Can''''t connect to MySQL server on localhost (10061)解决方法
    • MySQL日期数据类型、时间类型使用总结
    • 超详细mysql left join,right join,inner join用法分析
    • windows下MySQL5.6版本安装及配置过程附有截图和详细说明
    • MySQL创建用户与授权方法
    • MySQL 的CASE WHEN 语句使用说明
    • mysql中int、bigint、smallint 和 tinyint的区别详细介绍
    • mySQL中replace的用法
    • mysql update语句的用法详解
    • mysql 添加索引 mysql 如何创建索引
    上一篇:MAC版修改MySQL初始密码的方法
    下一篇:MySQL5.7.10 安装文档教程详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL 序列 AUTO_INCREMENT详解及实例代码 MySQL,序列,AUTO,INCREMENT,详解,