先建立動態鏈接服務器﹐然后再寫個觸發器讓兩個表同步﹗分兩步走﹗1.
--访问不同电脑上的数据库(远程只要联好网就一样)--如果经常访问或数据量大,建议用链接服务器--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
go--查询示例
select * from srv_lnk.数据库名.dbo.表名--导入示例
select * into 表 from srv_lnk.数据库名.dbo.表名go
--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'
--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
--导入示例
select * into 表 from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
2.
觸發器
CREATE TRIGGER TRIG_Tab
ON A.dbo.a_1
FOR UPDATE
AS
IF UPDATE(name)
BEGIN
UPDATE B.dbo.b_1 SET user_name=A.name FROM a_1 a WHERE user_id=a.id
ENDGO
--访问不同电脑上的数据库(远程只要联好网就一样)--如果经常访问或数据量大,建议用链接服务器--创建链接服务器
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
go--查询示例
select * from srv_lnk.数据库名.dbo.表名--导入示例
select * into 表 from srv_lnk.数据库名.dbo.表名go
--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk','droplogins'
--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
--导入示例
select * into 表 from openrowset('SQLOLEDB'
,'sql服务器名';'用户名';'密码'
,数据库名.dbo.表名)
2.
觸發器
CREATE TRIGGER TRIG_Tab
ON A.dbo.a_1
FOR UPDATE
AS
IF UPDATE(name)
BEGIN
UPDATE B.dbo.b_1 SET user_name=A.name FROM a_1 a WHERE user_id=a.id
ENDGO
update b.dbo.b_1 set user_name=a.name from inserted a where a.id=b.dbo.b_1.user_id
create trigger t_a on a_1 for delete as
delete b.dbo.b_1 from deleted a where a.id=b.dbo.b_1.user_id
ON A.dbo.a_1
FOR UPDATE
AS
IF UPDATE(name)
BEGIN
UPDATE server2.B.dbo.b_1 SET user_name=A.name FROM inserted a WHERE user_id=a.id
ENDGO