欢迎来到徐庆高(Tea)的个人博客网站
磨难很爱我,一度将我连根拔起。从惊慌失措到心力交瘁,我孤身一人,但并不孤独无依。依赖那些依赖我的人,信任那些信任我的人,帮助那些给予我帮助的人。如果我愿意,可以分裂成无数面镜子,让他们看见我,就像看见自己。察言观色和模仿学习是我的领域。像每个深受创伤的人那样,最终,我学会了随遇而安。
当前位置: 日志文章 > 详细内容

MySQL 更新字段的值为当前最大值加1的解决方案

2025年07月16日 Mysql
摘要:在mysql中,我们在执行update或者insert语句时,可以借助select语句更新一个字段,使其值更新为该字段的最大值加1。  在《mysql中自增长序列(@i:=@

摘要:在mysql中,我们在执行update或者insert语句时,可以借助select语句更新一个字段,使其值更新为该字段的最大值加1。

  在《mysql中自增长序列(@i:=@i+1)的用处及用法》中,介绍了如何在select语句中生成递增序列,《mysql 把查询结果更新或者插入到新表》介绍了把查询到的多条记录复制到另一张表中,均没有介绍如何更新数据库字段的值为当前最大值加指定步长。所以在本文中,楼兰胡杨将带着大家了解如何更新某个字段的值为当前最大值加指定步长1,步长也可以是其它满足诉求的值。

创建测试表

  使用以下 mysql 语句创建测试表test并写入三条测试数据:

create table test (
  `id` bigint(20) unsigned not null primary key auto_increment comment '主键id',
  incr_id int not null comment '递增序列',
  creator varchar(30) not null comment '创建者' 
) engine = innodb character set = utf8mb4 collate = utf8mb4_bin comment = '测试表';
insert into test(incr_id,creator) values (floor(1 + rand() * 100),"张三");
insert into test(incr_id,creator) values (floor(1 + rand() * 100),"张三丰");
insert into test(incr_id,creator) values (floor(1 + rand() * 100),"楼兰胡杨");

  表中incr_id用于演示如何更新它的值为其当前最大值加1。当然,令其如主键id一样支持auto_increment时,可以实现自增长,实现方案非常简单,本文不再赘述。这里主要讲述如何通过update select和insert select实现字段值递增的策略。

update select实现字段递增赋值

  首先使用聚合函数max来计算最大值,然后将其加1。以下sql将返回test表中incr_id字段的最大值并且加1:

select max(incr_id)+1 from test;

  运行此命令后,将返回一个包含最大值加1的单独的列。接下来,楼兰胡杨将此用作update语句的源值,以下实现方案基于嵌套子查询完成:

update test 
set incr_id = (
    select max_incr from (
        select max(incr_id) + 1 as max_incr from test
    ) as tmp
)
where id = 3;

  在这个更新dml中,我们在子查询语句中使用聚合函数max计算字段最大值,然后对其最大值加1。与前面的例子一样,where子句用于指定要更新的记录。这个方案因为耗内存、效率低而不适用于批量更新场景,但变量模拟自增方案适用于批量更新或复杂逻辑控制,实现脚本如下:

-- 自定义变量
set @max_incr = (select max(incr_id) + 1 from test);
-- 使用变量更新字段
update test set incr_id = @max_incr where id = 3;

insert select实现字段递增赋值

  在insert操作中实现字段递增赋值时,也是首先使用聚合函数max来计算最大值,然后将其加1。先介绍一下insert select语法糖:

insert into target_table (column1, column2, ...)
select value1, value2, ...
from source_table_a a join source_table_b b on a.id = b.a_id
where condition_clause;
  • target_table:用于插入数据的目标表。
  • source_table_a 和 source_table_b:源表,从中选择数据用于插入目标表。可以从多个表中选择数据并插入到目标表中,可以一个表。
  • value1, value2, …:被插入到目标表的值,既可以是从源表中选择的列,也可以是返回常量的表达式,更可以是一个常量。在编写select语句的时候,可以使用mysql支持的全部语法。

  下面使用上述语法糖新增一条记录,并且令incr_id字段的新值为其最大值加1:

insert into test ( `incr_id`, `creator`) 
select ifnull(max(incr_id), 0) + 1, '递增序列' from test;

  ifnull是专门处理 null 值的。若目标表的某些列不允许为 null,而假设 select 查询返回 null 值,会导致数据插入操作失败。这种书写格式与如下常见values写法区别很大:

insert into test(incr_id) values (floor(1 + rand() * 100),"普通insert操作");

小结

  本篇文章的内容基本上就是这些,我们来复盘一下。在本文中,我们提供了一些使用mysql select语句更新字段的示例,这些dml可以使用聚合函数或者嵌套子查询来计算要设置的新值。各位老铁无论选择哪种方式,都需要确保更新操作仅更新需要更新的记录,否则您可能会无意中、错误地❌更改了整张表的记录。楼兰胡杨还提到,如果您的表包含大量记录,使用select子查询操作可能会比较慢,而借助自定义变量计算最大值的方案可能更轻快。

到此这篇关于mysql 更新字段的值为当前最大值加1的文章就介绍到这了,更多相关mysql 更新字段的值为当前最大值加1内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!