SQL之用@@IDENTITY多表新增

SQL之用@@IDENTITY多表新增

作者:谢景,撰写时间:2019-2-22


多表新增思路:1、先新增一张表的数据,2、获取该数据的ID值,3、再将该ID值作为外键新增到另一张表
多表新增重点在于第二步骤:获取刚新增数据的ID值;

重点:@@IDENTITY 全局变量 numeric(18,0)
@@identity的作用是返回最后插入的标识值,可以使用它来获取插入数据后的标识符。
注意1:@@identity获取的是标识符,并不是ID
在表中,哪个字段设置为标识哪个字段才为标识符
设置标识如图:SQL之用@@IDENTITY多表新增
注意2:@@identity的作用是返回最后插入的标识值,如果@@identity位置写错,那么获取的标识就不是想要的数据。
比如:

//学院表标识为学院ID,年级表标识为年级ID
declare @numer int
insert into dbo.学院表(学院MC) values('IT学院')
set @[email protected]@identity  //此时@@identity获取'学院ID'
insert into  dbo.年级表(年级MC,学院ID) values('IT学院-1',@@IDENTITY)
 set @[email protected]@identity  //此时@@identity获取'年级ID'

多表新增代码如下:

    insert into dbo.学院表(学院MC) values('IT学院')
	insert into  dbo.年级表(年级MC,学院) values('IT学院-1',@@IDENTITY) //此时@@IDENTITY获取的是'学院ID'
	select dbo.年级表.* ,dbo.学院表.学院MC from dbo.学院表 
	inner join dbo.年级表 on dbo.年级表.学院ID=dbo.学院表.学院ID 
	where dbo.年级表.年级[email protected]@IDENTITY //此时@@IDENTITY获取的是'年级ID'

结果如图:
SQL之用@@IDENTITY多表新增