登录
首页 >  数据库 >  MySQL

记录如何解决mysql自增字段问题

来源:SegmentFault

时间:2023-02-16 15:21:43 280浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《记录如何解决mysql自增字段问题》,文章讲解的知识点主要包括MySQL、auto-increment,如果你对数据库方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

最近遇到mysql字段的自增问题,需要临时处理一下,然后就顺便补补课,这样就有了这样一篇文章。

1.自增值是什么

他是一个字段属性,是用来创建唯一标识的列的

The AUTO_INCREMENT attribute can be used to generate a unique identity for new rows:

  • show create table wp_options(举例)

  •    CREATE TABLE `wp_options` (    `option_id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,    `option_name` varchar(64) NOT NULL DEFAULT '',    `option_value` longtext NOT NULL,    `autoload` varchar(20) NOT NULL DEFAULT 'yes',

    • show table status

    • SELECT table_name,Auto_increment FROM information_schema.tables WHERE Table_Schema='wp';

    btw:

    官方提到:可以使用ALTER TABLE tbl AUTO_INCREMENT = 100;来恢复初始值,但是其实没有说明清楚,这个值有内部计数函数,所以如果遇到的情况是这个值本用过,但后来删除了,也是会继续累积增加上去的,但有一个情况,如果现在计数到100,而我插入一个1000,那么是可以通过这个语句来将1000恢复到101。

    另外官方还提到:auto_increment还会区分InnoDB和MyISAM,
    myisam可以使用多个字段作为一个auto_increment,而innodb不行,据此我的理解是,由于多个字段,所以唯一的属性被放大到2个字段的组合的唯一值,所以,id字段可以被复用,而innodb只能单个字段做auto_increment,所以如果在这个时候插入数据或者导入数据,而数据中的auto_increment字段的值是经常会出现重复的

  • truncate table 你的表名 (这样不但将数据全部删除,而且重新定位自增的字段)

  • 删除auto_increment字段,然后重新建字段并且授予auto_increment属性,这样就会重新排序

  •    ALTER TABLE 表名 DROP id;    alter table 表名 add id int(11)  null first;    ALTER TABLE 表名 MODIFY COLUMN id int(11) NOT NULL AUTO_INCREMENT,ADD PRIMARY KEY(id);


    引用参考:

    1. http://dev.mysql.com/doc/refman/5.1/en/example-auto-increment.html

    2. http://dev.mysql.com/doc/refman/5.6/en/innodb-auto-increment-handling.html


    原文链接:http://www.godblessyuan.com/2015/01/11/mysql-auto_increment/

    文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《记录如何解决mysql自增字段问题》文章吧,也可关注golang学习网公众号了解相关技术文章。

    声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
    相关阅读
    更多>
    最新阅读
    更多>
    课程推荐
    更多>