看了一下,SCOPE_IDENTITY貌似是最靠谱的,没有并发的问题。
但是我测试了一下,在不到40w的表里新增数据,用SCOPE_IDENTITY获取值很慢啊!比@@INDENTITY慢多了,@@INDENTITY大概在15ms以内,而SCOPE_IDENTITY就要100多ms。
才40w数据,就慢成这样,那几百w几千w条数据,那要变成什么样子了,除了IDENT_CURRENT、@@INDENTITY还有别的比较快速又保险的方式吗?
------------------------------------------
试试--
- SQL code
-
SET NOCOUNT ON; INSERT INTO TB(COL) VALUES ('TEST'); SELECT SCOPE_IDENTITY()
嗯嗯,可以了,原来是取值方式不对,我原来是
SELECT @id = SCOPE_IDENTITY() FROM tb
估计被赋值了很多次
现在用SELECT @id = SCOPE_IDENTITY()就好了
感谢感谢~~
本文探讨了在SQL Server中使用SCOPE_IDENTITY()函数获取插入记录ID的方法,并对比了其与@@IDENTITY的性能差异。通过正确的使用方式,解决了性能问题。
1699

被折叠的 条评论
为什么被折叠?



