龙空技术网

本地数据库(sql server)插入一条新数据时,同步到服务器数据库

中年农码工 1475

前言:

此时看官们对“访问不了服务器数据库”大体比较注意,小伙伴们都需要分析一些“访问不了服务器数据库”的相关资讯。那么小编在网上汇集了一些对于“访问不了服务器数据库””的相关资讯,希望姐妹们能喜欢,同学们快快来学习一下吧!

之前有个同学问我,本地数据库插入新数据时怎么同步到服务器上,当时我先想到是程序逻辑控制,作相应的处理。

但有时候我们程序不太好处理,那能不能从数据库入手呢,数据库不是有触发器(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 trgteston productafter insertas 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;--插入的数据IDselect * into [你服务器表] from product where productid=@Proidexec sp_droplinkedsrvlogin 'black',nullexec sp_dropserver 'black'end

期间遇到些问题:开启TCP/IP协议

标签: #访问不了服务器数据库 #如何建立服务器数据库连接 #sqlserver联表更新 #数据库如何连接服务器服务 #数据库如何连接到服务器