zoukankan      html  css  js  c++  java
  • 本地数据库(sql server)插入一条新数据时,同步到服务器数据库

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

    但有时候我们程序不太好处理,那能不能从数据库入手呢,数据库不是有触发器(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协议

     

  • 相关阅读:
    iOS开发快捷键
    通达信指标函数说明大全(2014)(转)
    windows下的wxWidgets环境配置
    Qt->数字格式化
    被称"硬盘杀手"的几个win7系统服务如何关闭(转)
    关闭系统索引(转)
    SSD固态硬盘优化(转)
    通达信的文件目录结构(转)
    Macdrive8破解版如何激活
    IOS6.0调用通讯录和之前的差别
  • 原文地址:https://www.cnblogs.com/MrBlackJ/p/8663975.html
Copyright © 2011-2022 走看看