zoukankan      html  css  js  c++  java
  • 由浅入深讲解数据库中Synonym的使用方法

    1.Synonym的概念

      Synonym(同义词)是SQL Server 2005的新特性。推出已经有几年的时间了。我们可以简单的理解Synonym为其他表的别名。本文中使用Northwind数据库为示例:

      Create Synonym MyCustomers FOR Customers

      为Customers表创建一个Synonym,叫MyCustomers。 我们可以把这个MyCustomers当作一个普通的表,可以对它进行查询,更新,删除和插入。例如:

      查询: Select * from MyCustomers.

      插入: Insert into MyCustomers (CustomersID, CompanyName) values ('Tom', 'MS')

      所有的操作,和普通的表没有区别。

      2.Synonym的实际应用

      在你的程序发布的时候,你突然发现你需要更改某个表名,或字段名。而你的程序已经不可能修改。这时,怎么办呢?那就创建Synonym吧。当然,在SQL2000时代,你可以使用view来做这个事情,或sprocs或udf等。但Synonym有其它所不能的功能,那就是跨数据库,跨服务器

      3.Synonym在同一服务器上的不同数据库

      对于同一服务器上的不同数据库,我们可以使用Synonym,将其他数据库中的表或view或sprocs及udf在本数据库中映射别名。这样,就可以不用更改连接字符串,而在当前对话数据库的情况下,获取其他数据库的数据,并对它进行,查询,更新,删除和插入工作。

      先假设已经存在Northwind数据库,然后,再建一个数据库。我们在新的数据库上,创建Customer表的Synonym.

      Create Synonym MyCustomers For Northiwind.dbo.Customers

      需要大家注意的是,后面需要写清那个数据库,那个表,中间dbo为表的owner.

      然后,运行 Insert into MyCustomers (CustomersID, CompanyName) values ('Tom', 'MS')

      和Select * from MyCustomers. 看看是不是真的像普通表那样。

      4.Synonym在不同服务器上的不同数据库

      假设一下,我们有一台数据库服务器SQLTest。上面有个数据库叫Northwind。我们本地还有一台数据库服务器。叫LocalTest. 其上面有一数据库叫Northwind或其他什么的。突然有一天,为了使本地的数据库跑的更快,本地的老数据被移到SQLTest上去了,本地只保存最近更新的。那老数据总还是要用的,怎么样实现不同服务器之间的数据操作呢?那就用Synonym吧。如下:

      Create Synonym MyCustomers For SQLTest.Northiwind.dbo.Customers

      你可能会发现,只是在上面这个例子的基础上,加了个机器名字。就这么简单?不是吧?那台服务器还不一定知道用户名和密码呢。对,是的,还要在本地服务器上,注册一下远程的服务器。使用sp_addlinkedServer,此存储过程定义如下所示:

      Exec sp_droplinkedsrvlogin davalSQL2005,Null

      Exec sp_dropServer davalSQL2005

      EXEC sp_addlinkedServer

      @Server='davalSQL2005',--被访问的服务器别名

      @srvproduct='',

      @provider='SQLOLEDB',

      @datasrc='D12' --要访问的服务器

      EXEC sp_addlinkedsrvlogin

      'davalSQL2005', --被访问的服务器别名

      'false',

      NULL,

      'sa', --账号

      '123456' --密码

      Select * from MyCustomers

    例如 

    Exec sp_droplinkedsrvlogin DB98,Null
    Exec sp_dropServer DB98
    EXEC sp_addlinkedServer
    @Server='DB98',--被访问的服务器别名
    @srvproduct='DB98',
    @provider='SQLOLEDB',
    @datasrc='10.72.240.121' --要访问的服务器的ip地址
     
    EXEC sp_addlinkedsrvlogin
    'DB98', --被访问的服务器别名
    'false', NULL,
    'oaflow', --账号
    '123456' --密码

  • 相关阅读:
    RabbitMQ + topic发送消息+python
    maven下载依赖jar包失败处理方法--下载jar包到本地并安装到maven仓库中
    Jmeter--thrift接口压测
    将jar文件加到maven的local repository中
    在Mac机器上给ITerm2配置lrzsz,便捷的传输文件到远程服务器上
    linux iptables 开启和关闭服务端口号
    centos 安装PGSQL
    pgsql 常用的命令
    web压力测试工具
    centos安装 mysql
  • 原文地址:https://www.cnblogs.com/yachao1120/p/10154660.html
Copyright © 2011-2022 走看看