怎么将一条记录添加到同一数据库的两个表中 C# ASP.NET

同一个数据库,两个表的字段名不同,比如表A:Id、name、sex、phone,Id是主键;表B:BId、Bname、Bphone、Id,BId是主键自增;A表的Id和B... 同一个数据库,两个表的字段名不同,比如表A:Id、name、sex、phone,Id是主键;表B:BId、Bname、Bphone、Id,BId是主键 自增;A表的Id和B表的Id相同,当点击button添加一条记录时,表A表B插入这一条记录。表A的name和表B的Bname添加的内容一样,表A的phone和表B的Bphone添加的内容一样,用C#怎么写?? 展开
 我来答
匿名用户
推荐于2016-09-19
展开全部
第一步,执行这个脚本:在tableB中创建一个触发器
create TRIGGER [dbo].[trgInertTableA] ON [dbo].[TableB] AFTER INSERT
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
declare @id int
--1.0如果这句能得到这个ID,则直接用这句
select @id=BID FROM INSERTED
--2.0如果1.0这句不能得到@id,则使用下面的2.0语句
declare @name nvarchar(100)
declare @phone nvarchar(100)
select @name=BName,@phone=BPhone from INSERTED
select @id=BID from TableB where BName=@name and BPhone=@phone
--3.0 执行插入
if not exits(select 1 from TableA where Name=@name and Phone=@phone)
begin
insert into TableA(ID,Name,Phone) values(@id,@name,@phone)
end

END

--第二步,执行插入TableB

private void AddRecord_TableB()
{
String sName=this.TextBox_Name.Text.Trim();
String sSex=this.TextBox_SEX.Text.Trim();//或者用 DropDownList ,则为ddlSex.SelectedValue;
String sPhone=this.TextBox_Phone.Text.Trim();
String sql="insert into TableB(Bname,Bphone,Sex) values(@name,@phone,@sex)";
SqlConnection cn=new SqlConnection(connectionString);
SqlCommand cmd=new SqlCommand(sql,cn)
cmd.Parameters.AddWithValues("@name",sName);
cmd.Parameters.AddWithValues("@phone",sPhone);
cmd.Parameters.AddWithValues("@sex",sSex);
if(cn.State!=ConnectionState.Opened)
cn.Open();
cmd.ExecuteNonQuery();
if(cn.State!=ConnectionState.Closed)
cn.Close();
}
育知同创教育
2016-02-17 · 百度知道合伙人官方认证企业
育知同创教育
1【专注:Python+人工智能|Java大数据|HTML5培训】 2【免费提供名师直播课堂、公开课及视频教程】 3【地址:北京市昌平区三旗百汇物美大卖场2层,微信公众号:yuzhitc】
向TA提问
展开全部
C# ASP.NET将一条记录添加到同一数据库的两个表中的实现方法:
if exists(select 1 from sysobjects where name='proc_insert')
drop procedure proc_insert
gocreate procedure proc_insert
@number2 varchar(20),
@number3 varchar(20)
as
begin transaction
declare @errornum int,@number varchar(30)
set @errornum=0 insert into tb1 values(@number2,@number3) set @errornum=@errornum+@@error
set @number=@number2+CONVERT(varchar(20),@@identity) --CAST(@@identity AS varchar(30)) insert into tb2 values(@number,@number3)
set @errornum=@errornum+@@error if @errornum<>0
begin
rollback transaction
end
else
begin
commit transaction
end
goexec proc_insert 'qwe','123'
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
雨落雾起霜降临
2014-03-26
知道答主
回答量:15
采纳率:0%
帮助的人:17.2万
展开全部
要咋个写嘛,吧数据插入B表,在查出来,插入A表,不就完了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xiongqi0010
2014-03-25 · 超过46用户采纳过TA的回答
知道小有建树答主
回答量:110
采纳率:0%
帮助的人:91.9万
展开全部
insert into A select * from B
追问
A表只有部分字段插入了B表,而且B表的Id是自增的,要怎么写?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式