您好,欢迎来到刀刀网。
搜索
您的当前位置:首页【mysql】知识点

【mysql】知识点

来源:刀刀网

一、mysql如何让自增id归0

  • 当你不再需要该表时, drop
  • 当你仍要保留该表,但要删除所有记录时, truncate
  • 当你要删除部分记录时(always with a WHERE clause), delete.

方法一: 如果曾经的数据都不需要的话,可以直接清空所有数据,并将自增字段恢复从1开始计数 

truncate table 表名 

方法二: 许多时候希望table中数据的id不要从1开始,像qq, id从10000开始
代码如下:

alter table 表名 AUTO_INCREMENT=10000;
而且该语句也适用于修改现有表的id上, 比如大批量删除数据后,想id从654321退回123456开始

alter table 表名 AUTO_INCREMENT=123456;

但是经过实际测试, 单机的Mysql没有问题, Mysql Cluster下是无效的,可能在主键上的机制,还是有所不同。

二、mysql数据表增加列

  因为Drop Table会把数据也删除掉,要增加数据列的时候,最好用Alter语句。如:

alter table OrderSearchSummary add IsMonthly int(11) not NULL DEFAULT 0;

alter table OrderSearchSummary add DistributorFirstName varchar(50);

三、存在则更新,不存在则增加

  在实际应用中,经常碰到导入数据的功能,当导入的数据不存在时则进行添加,有修改时则进行更新

在刚碰到的时候,第一反应是将其实现分为两块,分别是判断增加,判断更新。

后来发现在mysql中有  ON DUPLICATE KEY UPDATE一步就可以完成。

该语句是基于唯一索引或主键使用,比如一个字段a被加上了unique index,并且表中已经存在了一条记录值为1:

下面两个语句会有相同的效果:

INSERT INTO table (a,b,c) VALUES (1,2,3)  
  ON DUPLICATE KEY UPDATE c=c+1;  
  
UPDATE table SET c=c+1 WHERE a=1;

 ON DUPLICATE KEY UPDATE后面可以放多个字段,用英文逗号分割。

INSERT INTO FerDB.RedisConfig(`RedisKey`, `RedisValue`, `RedisDesc`, `CreateDataTime`, `ExpiredMinutes`, `IsEncrypt`, `IsAdmin`, `EnableEdit`) 
VALUES ('urn: MinTimeDiff', '120', '最低時間差(分鐘),默認120,參考範圍(30~600)', '2019-01-25 08:00:00', '14400', '0', '0', '1') 
ON DUPLICATE KEY UPDATE RedisValue='120', RedisDesc='最低時間差(分鐘),默認120,參考範圍(30~600)', CreateDataTime='2019-01-25 08:00:00', 
ExpiredMinutes='14400', IsEncrypt='0', IsAdmin='0', EnableEdit='1';

 

转载于:https://www.cnblogs.com/peterYong/p/1039.html

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- gamedaodao.com 版权所有 湘ICP备2022005869号-6

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务