吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1643|回复: 7
收起左侧

[求助] SQLITE 如何让主键全部加一?

[复制链接]
Mr.Cedric 发表于 2021-12-18 22:24
25吾爱币
我想让ID大于3的ID全部加一,从原有的12345,变为12356。ID为主键
经过资料查询,update test set id=id+1 where id > 3
但是这条语句因为是批量修改,会触发唯一性的问题,不能进行修改。
我试过这样的语句其实也是不行的,并且在Sqlite中Update和order by不能连用。
update test set id=id+1 where id IN (SELECT id FROM test where id>3 order by -id);
请问是否有办法通过一条SQL语句实现该想法,谢谢!
我需要的是一个有效简便的解决方法,如果解决问题,必采纳!
image.png

最佳答案

查看完整内容

两条SQL可以吗 update test set id = -id-1 where id > 3 update test set id = -id where id < -4

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

hate 发表于 2021-12-18 22:24
两条SQL可以吗

update test set id = -id-1 where id > 3
update test set id = -id where id < -4
xiakor 发表于 2021-12-18 23:12
忧郁之子 发表于 2021-12-18 23:23
举个例子比较能说明问题
create table testtable(
id int  identity primary key,
test varchar(25) null)

首先我创建一个表,ID为主键,并且设置为自动增加(一般默认为从1开始)

我现在插入几条数据

insert into testtable(test)
values('我')


insert into testtable(test)
values('你')

insert into testtable(test)
values('他')

结果如下:
1 我
2 你
3 他

注意我上面的insert语句是没有对id赋值的,是自动赋值,也自动增加1c



create table testtable(
id int  identity(seed,increment) primary key,
test varchar(25) null)

说明下参数:
seed:插入第一行时所使用的值,如设置为7,那么插入数据第一条的ID就为7
increment:添加到该行ID值与上一行ID值的增量值,比如我设置seed为7,increment为2,那么第一条为7,第二条就是9,第三条就是11
萋小磊 发表于 2021-12-19 01:08
创建一个副本表   导数据过去时候改一下id
zyy22664488 发表于 2021-12-19 11:41
把主键约束去了在更新呗,更完了在改回来
RustYou 发表于 2021-12-20 17:29
试一试触发器可以不
 楼主| Mr.Cedric 发表于 2021-12-24 21:05
我认真的看了每一个人的回答,创建新字段和新表都比较复杂,在SQLITE中很多语法都不支持,比如说去除主键再加上,和创建临时表一样,还有忧郁之子答主写的很长但我没明白他想表达什么,最终结贴就用两条sql的吧
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 17:59

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表