mysql 添加自动增量_如何根据MySQL中的组添加自动增量ID

bd96500e110b49cbb3cd949968f18be7.png

Here is the format of the table:

indexer group name id

1 abc a

2 abc b

3 xyz c

4 abc e

5 xyz d

Now i want it to be like,

indexer group name id

1 abc a 1

2 abc b 2

3 xyz c 1

4 abc e 3

5 xyz d 2

"id" should auto increment according to "group"

解决方案

Try this:

update yourtable t1

join (

select

tt.indexer, @rowno := if(@grp = `group`, @rowno + 1, 1) as id, @grp := `group`

from (select * from yourtable order by `group`, indexer) tt

cross join (select @rowno := 0, @grp := null) t

) t2

on t1.indexer = t2.indexer

set t1.id = t2.id

Edited:

If you want to insert a new row, you have to do it like this:

insert into yourtable

select '$indexer', '$group', '$name', coalesce(max(id), 0) + 1

from yourtable

where name = '$name'

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值