SQL之用@@IDENTITY多表新增
SQL之用@@IDENTITY多表新增
作者:谢景,撰写时间:2019-2-22
多表新增思路:1、先新增一张表的数据,2、获取该数据的ID值,3、再将该ID值作为外键新增到另一张表
多表新增重点在于第二步骤:获取刚新增数据的ID值;
重点:@@IDENTITY 全局变量 numeric(18,0)
@@identity的作用是返回最后插入的标识值,可以使用它来获取插入数据后的标识符。
注意1:@@identity获取的是标识符,并不是ID
在表中,哪个字段设置为标识哪个字段才为标识符
设置标识如图:
注意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'
结果如图: