首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

@@identity , SCOPE_IDENTITY,IDENT_CURRENT 三者的异同

--===================================================== --@@identity , SCOPE_IDENTITY,IDENT_CURRENT 三者的异同 --===================================================== --1.@@IDENTITY:  返回最后插入的标识值 IF OBJECT_ID('dbo.ta') IS NOT NULL    DROP TABLE dbo.ta; CREATE TABLE dbo.ta (  ID INT IDENTITY PRIMARY KEY ,  Col VARCHAR(5) ); INSERT INTO ta SELECT 'A' INSERT INTO ta SELECT 'B' INSERT INTO ta SELECT 'C' SELECT @@IDENTITY AS Iden    --Result : Iden -------------- 3 IF OBJECT_ID('dbo.tb') IS NOT NULL    DROP TABLE dbo.tb; CREATE TABLE dbo.tb (  tb_id INT IDENTITY PRIMARY KEY ,  tb_col VARCHAR(5) ); --当触发器存在时, 返回被触发的表Identity列的值,不考虑任何作用域 IF OBJECT_ID('dbo.tr_ta') IS NOT NULL    DROP TRIGGER dbo.tr_ta    GO CREATE TRIGGER tr_ta ON dbo.ta FOR INSERT AS BEGIN     INSERT INTO tb SELECT 'AA' END INSERT INTO ta SELECT 'D' INSERT INTO ta SELECT 'E' SELECT @@IDENTITY AS Iden  --返回tb表中Identity列的值为2 --Result : Iden -------- 2 --2.SCOPE_IDENTITY:返回当前作用域中的标识列内的最后一个标识值 INSERT INTO ta SELECT 'F' SELECT @@IDENTITY AS [Identity]; SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY]; --Result:返回tb表中最后的Identity为3,当前作用域中最后的Identity为6,即表ta中最后的Identity为6 Identity --------- 3 (1 row(s) affected) SCOPE_IDENTITY ---------- 6 (1 row(s) affected) --3.IDEN_CURRENT 返回指定的表或视图生成的最后一个标识值 INSERT INTO dbo.ta SELECT 'G' SELECT @@IDENTITY AS [Identity]; SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY]; SELECT IDENT_CURRENT('ta') AS [IDENT_CURRENT_ta]; SELECT IDENT_CURRENT('tb') AS [IDENT_CURRENT_tb]; --Result: Identity -------------- 4 (1 row(s) affected) SCOPE_IDENTITY -------------- 7 (1 row(s) affected) IDENT_CURRENT_ta -------------- 7 (1 row(s) affected) IDENT_CURRENT_tb -------------- 4 --打开新的一个会话,不执行任何插入,如下: SELECT @@IDENTITY AS [Identity]; SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY]; SELECT IDENT_CURRENT('ta') AS [IDENT_CURRENT_ta]; SELECT IDENT_CURRENT('tb') AS [IDENT_CURRENT_tb]; --Result: Identity --------------------------------------- NULL (1 row(s

02

mysql和sqlserver区别_一定和必须的区别

mysql支持enum,和set类型,sql server不支持 mysql不支持nchar,nvarchar,ntext类型 mysql的递增语句是AUTO_INCREMENT,而sql server是identity(1,1) sql server默认到处表创建语句的默认值表示是((0)),而在mysql里面是不允许带两括号的 mysql需要为表指定存储类型 sql server识别符是[],[type]表示他区别于关键字,但是mysql却是 `,也就是按键1左边的那个符号 sql server支持getdate()方法获取当前时间日期,但是mysql里面可以分日期类型和时间类型,获取当前日期是cur_date(),当前完整时间是 now()函数 mysql支持insert into table1 set t1 = ‘’, t2 = ‘’ ,但是sql server不支持这样写 mysql支持insert into tabl1 values (1,1), (1,1), (1,1), (1,1), (1,1), (1,1), (1,1) sql server不支持limit语句,是非常遗憾的,只能用top 取代limt 0,N,row_number() over()函数取代limit N,M mysql在创建表时要为每个表指定一个存储引擎类型,而sql server只支持一种存储引擎 mysql不支持默认值为当前时间的datetime类型(mssql很容易做到),在mysql里面是用timestamp类型

02

SQL Server 2008新特性——更改跟踪

在大型的数据库应用中,经常会遇到部分数据的脱机和多个数据库的合并问题。比如现在有一个全省范围使用的应用程序,每个市都部署了单独的相同的应用程序服务器和数据库服务器,每个月需要将全省所有市的数据全部汇总起来用于出全省的报表,这是一种很常见的数据库合并问题。再比如我们做了一个SmartClient的应用程序,每个客户端都有应用程序和数据库,另外还有一个中心数据库用于汇总所有客户端的数据。每个智能客户端上都可以对自己的数据库进行增删改查,一旦智能客户端连接到网络上时,系统就将客户端数据库中的数据更改全部应用到中心数据库中,这种偶尔连接的应用程序也是需要数据库的同步的。

03
领券