电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Mysql中實現(xiàn)修改主鍵自增值

瀏覽:8日期:2023-06-08 19:37:37
目錄Mysql修改主鍵自增值重置mysql自增主鍵的值方法總結Mysql修改主鍵自增值

一般情況下,修改表的主鍵自增值直接運行下面的語句,是能成功的。

alter table table_name AUTO_INCREMENT= XX;

但是最近項目遷移數(shù)據(jù)庫,發(fā)覺有一張表直接運行這語句修改自增值不生效,下面就這個問題來舉例說明。

1.首先,我在本地庫名叫做susunma的庫下面,新建一張表:

CREATE TABLE `family` (`uid` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增id',`name` varchar(25) NOT NULL COMMENT '姓名',`age` tinyint(4) NOT NULL COMMENT '年齡',PRIMARY KEY (`uid`)) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

2.插入主鍵值不連續(xù)的數(shù)據(jù):

INSERT INTO `family` (`uid`, `name`, `age`)VALUES(1, 'Susunma', 28),(2, 'Winnie', 25),(3, 'Peng', 24),(4, 'Jian', 32),(888, 'Jack', 17),(999, 'Tom', 16);

3.此時查詢記錄的最大值以及下一個自增值

select max(id) from family; ? #999select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#1000

我們會發(fā)現(xiàn),雖然表里面只有六條數(shù)據(jù),但是由于999記錄的插入,下一個自增值變成了1000。但是實際上我們想要下一個自增值為更小一點,比如定為10,因為記錄中uid為888, 999的情況,實際上只是項目的要求,為的是使得某個人的id可以特殊化,下面直接運行一下修改自增值的語句:

alter table family AUTO_INCREMENT= 10;

然后再查詢一下,自增值是否修改成功:

select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#1000

我們會發(fā)現(xiàn),并沒有修改成功,下一個自增值還是1000。所以就在想,難道是修改語句出了問題,所以就開始很納悶,因為語句并沒錯。之后,在用不同表調試間,我們就發(fā)現(xiàn)了:

當修改后的自增值大于已有記錄的最大值時,修改語句變得有效,比如,我們把例子中的自增值修改為比記錄中最大值999更大的值2000, 并且查詢下修改結果:

alter table family AUTO_INCREMENT=2000;select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#2000

我們會發(fā)現(xiàn),自增值的確變成了2000。也就是說當修改后的自增值小于已有記錄的最大值時,修改語句是無效的。

所以這里采取的解決方案的步驟如下:

1.先將大于10 的uid設置為比10小的值, 注意這里不要與已有記錄的uid的值重復,因為主鍵必須是唯一的:

update family set uid = 9 where uid = 999 limit 1;update family set uid = 8 where uid = 888 limit 1;

2.修改uid的自增值ID為10:

alter table family AUTO_INCREMENT=10;

3.再還原被修改uid的值:

update family set uid = 999 where uid = 9 limit 1;update family set uid = 888 where uid = 8 limit 1;

4.最后查詢下修改結果:

select AUTO_INCREMENT FROM information_schema.tables WHERE table_name='family' and table_schema = 'susunma'; ?#10

結果為10,這樣,就完成了。

重置mysql自增主鍵的值方法show create table [表名]

查看當前主鍵索引值

alter table [表名] auto_increment = [你希望的值]

設置你希望的索引值

切記你希望的索引值一定要大于當前表中的最小值

總結

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

主站蜘蛛池模板: 鲁尔圆锥接头多功能测试仪-留置针测试仪-上海威夏环保科技有限公司 | 脉冲布袋除尘器_除尘布袋-泊头市净化除尘设备生产厂家 | 北京易通慧公司从事北京网站优化,北京网络推广、网站建设一站式服务商-北京网站优化公司 | 齿轮减速电机一体机_蜗轮蜗杆减速马达-德国BOSERL齿轮减速机带电机生产厂家 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂 | 自动气象站_气象站监测设备_全自动气象站设备_雨量监测站-山东风途物联网 | 水轮机密封网 | 水轮机密封产品研发生产厂家 | 潜水搅拌机-双曲面搅拌机-潜水推进器|奥伯尔环保 | 缠绕机|缠绕膜包装机|缠绕包装机-上海晏陵智能设备有限公司 | 长沙一级消防工程公司_智能化弱电_机电安装_亮化工程专业施工承包_湖南公共安全工程有限公司 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | b2b网站大全,b2b网站排名,找b2b网站就上地球网 | 顶空进样器-吹扫捕集仪-热脱附仪-二次热解吸仪-北京华盛谱信仪器 | 武汉画册印刷厂家-企业画册印刷-画册设计印刷制作-宣传画册印刷公司 - 武汉泽雅印刷厂 | 杭州ROHS检测仪-XRF测试仪价格-百科 | 风淋室生产厂家报价_传递窗|送风口|臭氧机|FFU-山东盛之源净化设备 | 深圳美安可自动化设备有限公司,喷码机,定制喷码机,二维码喷码机,深圳喷码机,纸箱喷码机,东莞喷码机 UV喷码机,日期喷码机,鸡蛋喷码机,管芯喷码机,管内壁喷码机,喷码机厂家 | 创绿家招商加盟网-除甲醛加盟-甲醛治理加盟-室内除甲醛加盟-创绿家招商官网 | 水冷散热器_水冷电子散热器_大功率散热器_水冷板散热器厂家-河源市恒光辉散热器有限公司 | 石英粉,滑石粉厂家,山东滑石粉-莱州市向阳滑石粉有限公司 | 耐压仪-高压耐压仪|徐吉电气 | 小型单室真空包装机,食品单室真空包装机-百科| 老房子翻新装修,旧房墙面翻新,房屋防水补漏,厨房卫生间改造,室内装潢装修公司 - 一修房屋快修官网 | 深圳快餐店设计-餐饮设计公司-餐饮空间品牌全案设计-深圳市勤蜂装饰工程 | 衬塑管道_衬四氟管道厂家-淄博恒固化工设备有限公司 | 衬氟旋塞阀-卡套旋塞阀-中升阀门首页 | ZHZ8耐压测试仪-上海胜绪电气有限公司| 横河变送器-横河压力变送器-EJA变送器-EJA压力变送器-「泉蕴仪表」 | 液压油缸-液压缸厂家价格,液压站系统-山东国立液压制造有限公司 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰]-不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰] | 聚丙烯酰胺PAM-聚合氯化铝PAC-絮凝剂-河南博旭环保科技有限公司 巨野电机维修-水泵维修-巨野县飞宇机电维修有限公司 | 合肥废气治理设备_安徽除尘设备_工业废气处理设备厂家-盈凯环保 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 袋式过滤器,自清洗过滤器,保安过滤器,篮式过滤器,气体过滤器,全自动过滤器,反冲洗过滤器,管道过滤器,无锡驰业环保科技有限公司 | 合肥角钢_合肥槽钢_安徽镀锌管厂家-昆瑟商贸有限公司 | 智能气瓶柜(大型气瓶储存柜)百科 | 南溪在线-南溪招聘找工作、找房子、找对象,南溪综合生活信息门户! | 气动调节阀,电动调节阀,自力式压力调节阀,切断阀「厂家」-浙江利沃夫自控阀门 | 大立教育官网-一级建造师培训-二级建造师培训-造价工程师-安全工程师-监理工程师考试培训 | 贵州成人高考网_贵州成考网 | 专业的压球机生产线及解决方案厂家-河南腾达机械厂 |