首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql存在增加自增字段

需求: 已有的mysql数据,希望增加一个自增字段,并设置新数据初始值。 实际上不复杂,只是做个备忘。...alter table t_abc add column id int auto_increment primary key; /*执行完上面这一条,字段增加,但值为空*/ /*执行这一条,它会自动为存在数据自增字段赋初值...,其实隐含设置当前自增字段从1开始*/ alter table t_abc auto_increment; /*将所有数据增加10000*/ update t_abc set id=id+10000...; /* 前面的100 我们是任意指定,现在我们应该指定数据库中maxId+1作为下一个数据起始值*/ set @maxId=1; select max(id) into @maxId from...t_abc; /*中有3条数据,那么maxId 现在是10003*/ select @maxId+1 from dual; /* 10004 */ alter table t_abc auto_increment

11.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL存在数据添加自增 ID 字段

    系统环境:Ubuntu 数据库:MySQL5.7 主要是遗留问题,该本来只是用于分析,同事没有添加自增id,造成后续在处理时,遇到一些问题,权衡之后,决定对表新增一个自增id字段(中已经存在大量数据...,非业务),为了节省时间,以下是个人解决方法。...上面使用了大量replace,是因为里面的数据是爬虫所得,格式不统一,且文本中存在大量空格,跨行等特殊符号需要替换处理,同时为了避免文本中存在和分隔符相同符号,我们也将其替换为空。...其他字段省略 ); 将修改好数据直接再导入到新建数据库(新增ID字段,设置ID自增),同时注意导入时设置字符编码格式为UTF8mb4,防止出现中文乱码情况。...至此,对存在数据库添加自增ID操作完成。导出,添加行首空字符,再导入MySQL一共花费3个小时左右时间,基本都花费在导出和导入。

    3.5K10

    清空删除mysql

    Mysql清空(truncate)与删除中数据(delete)区别 为某基于wordpress搭建博客长久未除草,某天升级时候发现已经被插入了几万条垃圾留言,如果一条条删除那可真是累人活。...遂考虑直接进入mysql直接清空或者删除中数据。 本文记录一下这2种操作模式区别,目标对象是wp_comments,里面的所有留言均是垃圾留言,均可删除。...然后便有了以下2种方式(进入mysql操作界面后): truncate table wp_comments; delete * from wp_comments; 其中truncate操作中table...这两者都是将wp_comments中数据清空,不过也是有区别的,如下: truncate是整体删除(速度较快), delete是逐条删除(速度较慢)。...而delete删除以后,Identity依旧是接着被删除最近那一条记录ID加1后进行记录。 如果只需删除部分记录,只能使用DELETE语句配合where条件。

    8.1K20

    mysql常用功能之删除一张中重复数据&ab中a存在b不存在 数据

    在开发中,我们有可能会遇到这种情况: 1:删除一张中重复数据 2:AB两张通过主键关联,删除A存在而B中不存在数据。如下图: ? 这样怎么解决? 今天遇到一个问题。...相同数据在同一张表里出现了多次。我需求是删除多余数据,但要保留其中一条。 定义 表明 table_a ,判断唯一两个字段 c_1,c_2,无关字段data 中原始数据如下 ?...我思路是:再查询一个id 字段 ,我们group by 时候 id 字段只能查询到重复数据中一条。然后我们把这些id数据删除,就达到了去重效果。...可以看到有两行被删除了。这时再看看数据,数据已经变成了: ? 成功将重复数据删除。 如果重复数据是三条或者更多怎么办呢?很简单,再多执行几次这个SQL 就好了。...2 内容3 7 3 内容1 8 3 内容2 9 3 内容3 现在A删除了某条记录 如何能将B删除A没有的记录.

    4.1K40

    MySQL异步删除方法

    背景在MySQL中有大需要清理,该超过100GB,不敢直接delete或者truncate、drop,怕影响业务。...truncate会清空所有行,但结构及其约束、索引等保持不变;drop会删除结构及其所依赖约束、索引等。truncate会重置自增值;delete不会。...常见删除方式对于大场景,常见做法:小批量、分批删除;由于直接使用delete,是逐步删除,直接delete不带where条件肯定是不科学。...ibd文件,每次 truncate 文件大小由 innodb_async_truncate_size 控制当文件size足够小时候,终将.ibd文件删除drop大异步化相关参数支持动态设置, 无须重启实例该功能无需用户操作...建议数据量小时候,清空数据,使用truncate命令,删除可直接drop数据量大时候,使用创建硬链接方式,drop table后再逐步删除文件;使用TDSQL的话,打开异步删除配置参数,直接drop

    4.4K110

    实验三:SQL server 2005基于存在创建分区

    server 2005所使用分区,不断改善大型所面临性能、阻塞、备份空间、时间、运营成本等。...当和索引非常大时候,通过分区实现,可以将数据分为更小,更易于管理,获得更好可操作性能。本实验介绍基于存在来如何创建分区,管理分区。...一、实验目的:对于已经存在且不断增大情况下构建分区,管理分区,提高其性能。...二、主要步骤:对于已经存在,我们可以采取以下步骤来对其创建分区     1.创建分区函数     2.创建分区架构并关联到分区函数     3.删除已经存在聚集索引     4.基于分区架构重建聚集索引...4.对存在要创建分区为:Performance数据库下Orders.     5.对Ordersorderdate列按年进行水平分区 四、具体试验步骤:          1.

    94910

    快速安全删除MySQL

    要优化删除,需要了解其内部执行过程。 一、删除过程 删除原理上分为内存和磁盘两部分操作: 清除表相关buffer pool页面。 删除表相关磁盘文件。...1. buffer pool清除 删除时,MySQL会将在buffer pool中对应页面清除,这个过程中会对buffer pool上一个全局排它锁。...通常可以使用以下三个步骤删除: 创建文件硬链接。 drop table删除删除文件释放磁盘空间。 二、创建硬链接 一个磁盘上存储文件,可以由多个文件名引用。...mysql 498115543040 Oct 7 17:14 t1.ibd 其中第二个字段“1”表示文件只有一个inode指针,此时删除t1会实际删除磁盘文件。...{ibd,frm} | awk '{print "ln "$0" "$0".h"}' | bash 三、删除 drop table t1; MySQLdrop table操作会删除系统

    5.6K50

    MySQL——如何快速删除

    前言 线上有一个,大小为24G左右,没有什么重要数据,却一直没有优化,导致业务无法进行,在此环境上,所以我们开始了删除之路 步骤 复制表 我这里使用Navicat工具直接复制表,选择仅结构即可。...创建硬链接 如果不知道自己存储位置,可使用show variables like "datadir";查看自己数据存储位置。...ln instruction.frm instruction.frm.bak ln instruction.ibd instruction.ibd.bak 删除 DROP TABLE "表格名";...24G数据删除大概用了15秒左右 修改名 将我们刚才复制,名修改为线上正常使用名即可。...删除物理文件 切记大物理文件不可直接删除,直接操作会导致磁盘IO和CPU利用率升高,影响线上业务可使用truncate来进行删除操作。

    14910

    MySQL 删除数据

    MySQL 删除数据MySQL删除数据是非常容易操作,但是你在进行删除操作时要非常小心,因为执行删除命令后所有数据都会消失。...语法以下为删除MySQL数据通用语法:DROP TABLE table_name ;----在命令提示窗口中删除数据mysql>命令提示窗口中删除数据SQL语句为DROP TABLE:实例以下实例删除了数据...DROP TABLE kxdang_tbl;Query OK, 0 rows affected (0.8 sec)mysql>----使用PHP脚本删除数据PHP使用 mysqli_query 函数来删除...规定要使用 MySQL 连接。query必需,规定查询字符串。resultmode可选。一个常量。...可以是下列值中任意一个: * MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个) * MYSQLI_STORE_RESULT(默认)实例以下实例使用了PHP脚本删除数据 kxdang_tbl

    4.3K30

    python 多线程删除MySQL

    MySQL服务器所有信息,但是还不够,还缺2个列。...领导需要将不使用,全部删除掉。但是有一个前提:删除之前,一定要做备份。 二、MySQL备份问题 怎么备份呢?有2个方案 1. 使用mysqldump 备份单个,也就是要删除 2....创建脚本 诶,既然是要删除指定,那么我创建出那么,不就完事了吗? 结构不用完全和生产环境一样,弄成统一模板即可。 日记也不需要记录,临时而已! 完整代码如下: ? ? #!...查看MySQL错误日志,出现了not found名,就手动恢复一下! 所以,为了线上执行时,避免出现类似问题。将删除操作改为重命名操作,一旦出现问题,可以快速恢复!...所以执行之后,重命名会一直存在,存放个半年左右。等到功能稳定之后,一并删除

    6.7K50

    MySQL删除三种方式

    ,不删除结构,速度排第二,但不能与where一起使用 例如删除 user : truncate table user; delete from delete 是删除数据,不删除结构,速度最慢...,但可以与where连用,可以删除指定行 例如删除user所有数据 delete from user; 删除user指定记录 delete from user where user_id =...1; 三种方式区别 相同点 truncate和不带where子句delete,drop都会删除数据; drop,truncate都是DDL语句(数据定义语言),执行后会自动提交; 不同点 语句类型...delete 只删除数据不删除结构,truncate 删除后将重建索引(新插入数据后id从0开始记起),而 delete不会删除索引 (新插入数据将在删除数据索引后继续增加),drop语句将删除结构包括依赖约束...,触发器,索引等; 安全性:drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚; 返回值:delete 操作后返回删除记录数,而 truncate

    3.9K20
    领券