使用SQL更新两个表?
问题描述:
亲爱的所有人,
我创建了2个表:
table1栏:名称varchar(50),地址varchar(50),电子邮件地址varchar(50)
table2栏:移动bigint,EmailAddress varchar(50)
在这里,我想一次通过单个更新查询来更新两个表
请回复我
Dear All,
I created 2 tables:
table1 columns: name varchar(50), Address varchar(50), emailaddress varchar(50)
table2 columns: mobile bigint, EmailAddress varchar(50)
and here i want update both tables at a time in single update query
please reply me
答
最简单的方法是创建一个存储过程,该存储过程创建一个Transaction,然后同时执行更新和Commits,如果它们都起作用,否则它会回滚到确保数据库完整性.
Google将为您找到很多例子.
Easiest way is to create a Stored Procedure which creates a Transaction, then does both updates and Commits if they both work - otherwise it does a Rollback to ensure DB integrity.
Google will find you many, many examples.
使用所需的输入类型字段创建存储过程,并将数据同时插入两个表中. 例如
Create a stored procedure with desired input type fields and insert the data into both the tables simultaneously.
e.g
CREATE PROCEDURE [dbo].[spMyInsertData]
(@name nvarchar(50), @address nvarchar(max), @emailAddress nvarchar(max), @mobile bigint )
as
declare @insertQuery nvarchar(max)
Begin
Begin Try
set @insertQuery = ''INSERT INTO table1(name,address,emailaddress)
values(''+@name+'',''+@address+'',''+@emailAddress+'')''
set @insertQuery = @insertQuery+'' INSERT INTO table2(mobile,EmailAddress)
values(''+@mobile+'',''+@emailAddress+'')''
print @insertQuery;
exec sp_executeSql @insertQuery;
End Try
Begin Catch
print @@error
End Catch
End