之前有个同学问我,本地数据库插入新数据时怎么同步到服务器上,当时我先想到是程序逻辑控制,作相应的处理。
但有时候我们程序不太好处理,那能不能从数据库入手呢,数据库不是有触发器(Trigger)吗,应该是可以的,这里就用这个来做吧。一些东西也是不太懂,网上找的资料,感谢那些人默默奉献的好人。如有误解,欢迎各位大神指正!
1、首先,了解什么是触发器
触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。
简单讲下创建trigger的语法:
CREATE TRIGGER trigger_name ON table_name [WITH ENCRYPTION] FOR | AFTER | INSTEAD OF [DELETE, INSERT, UPDATE] AS T-SQL语句 GO
2、怎么连接到服务器的数据库
select * from sys.servers --查看当前的服务 EXEC sp_addlinkedserver @server='black',--被访问的服务器别名(习惯上直接使用目标服务器IP,或取个别名如:black) @srvproduct='', @provider='SQLOLEDB', @datasrc='192.168.1.36', --要访问的服务器 @catalog='anmax' --数据库名称 exec sp_addlinkedsrvlogin 'black','false',null,'sa','sa123456' --(balck->前面取的别名;sa->数据库用户名;sa123456->密码) select top 10 * from [black].[anmax].dbo.ad --测试是否成功 exec sp_droplinkedsrvlogin 'black',null --移除登陆用户 exec sp_dropserver 'black' --移除服务
3、同步插入的数据
create trigger trgtest on product after insert as begin --select * from sys.servers --查看当前的服务 EXEC sp_addlinkedserver @server='black',--被访问的服务器别名(习惯上直接使用目标服务器IP,或取个别名如:JOY) @srvproduct='', @provider='SQLOLEDB', @datasrc='192.168.1.36', --要访问的服务器 @catalog='anmax' --数据库名称 exec sp_addlinkedsrvlogin 'black','false',null,'sa','sa123456' --执行同步代码 declare @proId int; set @proId=@@identity;--插入的数据ID select * into [你服务器表] from product where productid=@Proid exec sp_droplinkedsrvlogin 'black',null exec sp_dropserver 'black' end
期间遇到些问题:开启TCP/IP协议