asp.net老项目运维,出现的问题6之数据库

数据库会有很多张表,表内一般会有自增列,如果想统一管理这个自增数值,可以使用如下方法,放在一个存储过程中,想用的时候调用存储过程即可生成数据库层面的全局唯一值:

复制代码
create procedure [dbo].[P_getSeqID] 
as
begin
      declare @NewSeqID int

      set NOCOUNT ON
      insert into table1 (SeqID) values ('abc')   
      set @NewSeqID = scope_identity()   
      delete from table1 WITH (READPAST)

return @NewSeqID

end
GO

解释一下存储过程

declare SeqID int

这句表示定义一个变量叫NewSeqID,是int型;

insert into table1 (SeqID) values ('abc')

你要提前建立一张表table1,加一个字段叫ID(标识自增),另一个字段叫SeqID,往SeqID里面写任意值,这里我写abc;

set @NewSeqID = scope_identity()

给NewSeqID赋值,scope_identity() 是从本存储过程中获取最后一次插入table1表数据行的自增值;

delete from table1 WITH (READPAST)

将插入的值删掉,标尺table1表永远是空的,为了避免冗余,WITH (READPAST) 是避免并发脏读情况发生。最后返回NewSeqID

相关推荐
changhong198617 分钟前
mybatisPlus打印sql配置
数据库·sql
l1t19 分钟前
用官方安装脚本安装duckdb 1.5并测试加载各种插件
数据库·docker·postgresql·kylin
jinanmichael20 分钟前
Mybatis控制台打印SQL执行信息(执行方法、执行SQL、执行时间)
数据库·sql·mybatis
J2虾虾34 分钟前
给Redis增加密码
数据库·redis·缓存
Mr数据杨35 分钟前
【Dv3Admin】Django通用自定义工作台卡片
数据库·django·sqlite
山峰哥1 小时前
SQL优化全攻略:从索引策略到Explain实战解析
大数据·数据库·sql·oracle·性能优化·编辑器
JuneXcy1 小时前
第9章 关系模式的规范化设计理论
数据库·mysql
larance2 小时前
NebulaGraph 数据库部署与运维指令清单
linux·服务器·数据库
想不明白的过度思考者2 小时前
【MyBatis 知识点解析】#{} 与 ${} 的区别及 SQL 注入实战演示
java·数据库·spring boot·sql·mybatis
tongxh4232 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql