CSDN中自增项的改变

zxy_yyy 2018-05-23 09:01:49
最近刚开始学习SQL
如果在表中设置 自增项为1 2 3
删除2项后
自增项变为1 3
如何才能显示为 1 2?
...全文
1400 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
chenjiecao123 2018-06-05
  • 打赏
  • 举报
回复
你这个是相对自增长的主将 int数据进行自定义,默认就是删了,但是数据还是累计增加的,可以用下面的语句进行强制改: DBCC CHECKIDENT ('Sales.Customers', RESEED, 91) Sales.Customers是指定数据库中的表,91就是要目标设定值,你这里改成2即可 满意的话 结贴吧 谢谢
吉普赛的歌 版主 2018-05-24
  • 打赏
  • 举报
回复
USE tempdb
GO
IF OBJECT_ID('t') IS NOT NULL DROP TABLE t
GO
CREATE TABLE t(id INT IDENTITY(1,1) PRIMARY KEY,n NVARCHAR(10))
GO
SET NOCOUNT ON
INSERT INTO t (n) VALUES('a')
INSERT INTO t (n) VALUES('b')
DELETE FROM t WHERE n='b'

--必须设置 SET IDENTITY_INSERT tableName ON
--才能插入显式的 id 值
--不过你到最后会发现, 一般情况下没这个必要
--如果真的希望一直连续,可以用其它列去做逻辑上的处理,标识列不是专门干这个的
SET IDENTITY_INSERT t ON
INSERT INTO t(id,n) VALUES(2,'c')
SET IDENTITY_INSERT t OFF

SELECT * FROM t
/*
id	n
1	a
2	c
*/
游北亮 2018-05-24
  • 打赏
  • 举报
回复
你只是希望查询出来的记录显示行号吧?用Row_number,比如:
SELECT  * ,
        ROW_NUMBER() OVER ( ORDER BY id) AS 行号
FROM    表名
二月十六 版主 2018-05-23
  • 打赏
  • 举报
回复
1、2、3已经存在了吗,存在之后删除2,还是先存在1、2然后删除2之后,再次插入变成3?

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧