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 @numer=@@identity  //此时@@identity获取'学院ID'
insert into  dbo.年级表(年级MC,学院ID) values('IT学院-1',@@IDENTITY)
 set @numer=@@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.年级表.年级ID=@@IDENTITY //此时@@IDENTITY获取的是'年级ID'

结果如图:
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值