zoukankan      html  css  js  c++  java
  • SQLServer中同义词Synonym的用法

    以前一直认为SqlServer中的同义词(Synonym)没有什么用处,所以也一直没有去查它的语法格式。今天碰到一个问题,用Synonym来解决再好不过了。问题是这样子的,我的系统中用到了多个数据库,然后因为各个数据库中的某些数据需要同步,所以我就在其中的某个数据库中的表中添加触发器,来同步更新其它数据库中的数据。举例如下:
    有两个数据库A和B,分别有表a1与b1,然后我在表a1创建了触发器来更新表b1中的数据,触发器大概如下:

    create trigger tu_a1 after update
    as
    ……
    update t2 set t2.字段=t1.字段
    from inserted t1,B..b1 t2 where t1.字段=t2.字段


    反正就是,我在a1的触发器中用到了B..这种方式来引用数据库B中的对象。

    然后问题就来了,今天老板说在同一台服务器上要同时安装多个系统。那么就需要把数据库A和数据库B复制多份,当然复制出来的数据库名字就不能叫A和B了,可能叫A1与B1。那么A1中的触发器就不能更新B1中的数据了,因为A1中的触发器是使用B..这种方式来引用的。这种情况下,必须将全部的B..全部换成B1..。这样,如果这样引用的地方多了,那就是一场灾难了。

    使用同义词Synonym就能很好的解决这个问题,首先大概说一下同义词(Synonym)的作用。
    同义词:就是定义一个字符串名称,用来代替一个有意义的引用对象。

    在上例中,我可以用Bb1这个字符串来代代B..b1,那么以后我要操作B..b1这表,就可以直接操作Bb1,与操作前者一样的效果。那么,在部署多套系统时,只需修改一下新数据库中这个同义词的引用就可以了,触发器根本不需要修改。

    下面是“创建,删除,引用”同义词的sql语句示例,注意,同义词不提供修改的功能,所以一旦创建了,就只能删除再重建,是不能够修改的。

    创建同义词
    create synonym Bb1
    from B..b1

    使用同义词
    insert into Bbl(……) values (……)

    引用同义词
    select * from Bbl

    删除同义词
    drop synonym Bb1

    查询所有同义词
    select * from sys.synonyms


    注意:只有SqlServer2005及以后的版本中才有Synonym。ong>。

    出处:http://www.lmwlove.com/ac/ID1042

    立刻行动,坚持不懈,不断学习!
  • 相关阅读:
    centos7 yum 方式安装nginx
    在Windows系统下用命令把应用程序添加到系统服务
    WPF内置命令
    Json解析实例
    端口占用的问题
    WPF里的报警闪烁效果
    python类中的一些神奇方法
    python中交换两个变量值的方法
    lambda应用
    python函数不定长参数
  • 原文地址:https://www.cnblogs.com/deng779256146/p/7828126.html
Copyright © 2011-2022 走看看