SQL Server stored procedure to insert in multiple tables(在多个表中插入 SQL Server 存储过程)
问题描述
我有 2 个表,custlogin 和 custinfo:
I have 2 tables, custlogin and custinfo:
客户登录:
custid int primary key auto notnull
custusename varchar(25)
custpassword varchar(50)
客户信息:
custid foriegnkey custlogin.custid ondelete set NULL
custfirstname varchar(25)
custlastname varchar(25)
custaddress varchar(100)
我想写一个存储过程来插入两个表
I want to write a stored procedure which will insert into both tables
更准确地说,使用 custusername custpassword 插入 custlogin,这将返回 custid 以用作 custinfo的外键代码>.
More precisely, insert into custlogin with custusername custpassword, which would return custid for use as foreign key for custinfo.
我搜索了很多,但没有找到任何解决方案.
I have searched much but I didn't find any solution.
推荐答案
如下所示.在这种情况下,您可以使用 SCOPE_IDENTITY() 来获取最后一个自动生成的 ID,其范围是这个存储过程:
It will be something like below. You can use SCOPE_IDENTITY() to get the last autogenerated ID withing the scope which is this stored proc in this case:
create procedure NameOfYourProcedureHere
as
begin
SET NOCOUNT ON;
SET XACT_ABORT ON;
insert into custlogin(custusename, custpassword)
values ('','') -- put values here (from parameters?)
insert into custinfo(custid, custfirstname, custlastname, custaddress)
values (SCOPE_IDENTITY(), '', '', '') -- put other values here (from parameters?)
SET NOCOUNT OFF;
SET XACT_ABORT OFF;
end
这篇关于在多个表中插入 SQL Server 存储过程的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在多个表中插入 SQL Server 存储过程
基础教程推荐
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- 在多列上分布任意行 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- oracle区分大小写的原因? 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
