设为首页 收藏本站
查看: 854|回复: 0

[经验分享] SQL Server2005 Synonym的使用

[复制链接]

尚未签到

发表于 2016-11-10 09:54:35 | 显示全部楼层 |阅读模式
--> Title : SQL Server2005 Synonym的使用
--> Author : wufeng4552
--> Date : 2009-10-30
1.Synonym的概念
 
Synonym(同义词)是SQL Server 2005的新特性。可以简单的理解Synonym为其他對象的别名。
語法
CREATE SYNONYM [ schema_name_1. ] synonym_name FOR < object >
< object > :: =
{
[ server_name.[ database_name ] . [ schema_name_2 ].| database_name . [ schema_name_2 ].| schema_name_2. ] object_name
}
在建立同義字時,基底物件不需要存在。在執行階段,SQL Server 會檢查基底物件是否存在。
各參數涵義如下:
schema_name_1 :指定建立同義字的結構描述。如果未指定 schema,SQL Server 2005 會使用目前使用者的預設結構描述。
synonym_name :這是新同義字的名稱。
server_name :這是基底物件所在的伺服器名稱。
database_name :這是基底物件所在的資料庫名稱。如果未指定 database_name,就會使用目前資料庫的名稱。
schema_name_2 :這是基底物件的結構描述名稱。如果未指定 schema_name,就會使用目前使用者的預設結構描述。
object_name :這是同義字參考的基底物件名稱。
注:
若要使用给定架构创建同义词,用户必须满足以下条件:
(1)拥有此架构或具有 ALTER SCHEMA 权限以
(2)具有 CREATE SYNONYM 权限。
(3)是 db_owner 的成员。
(4)是 db_ddladmin 固定数据库角色的成员
可以为下列对象类型创建同义词:
程序集 (CLR) 存储过程; 程序集 (CLR) 表值函数
程序集 (CLR) 标量函数; 程序集聚合 (CLR) 聚合函数
复制筛选过程; 扩展存储过程
SQL 标量函数;SQL 表值函数SQL 内联表值函数;
SQL 存储过程视图; 表(用户定义)
2.Synonym的实际应用
在你的程序发布的时候,你突然发现你需要更改某个表名,或字段名。而你的程序已经不可能修改。这时,怎么办呢?那就创建Synonym吧。当然,在sql2000时代,你可以使用view来做这个事情,或sprocs或udf等。但Synonym有其它所不能的功能,那就是跨数据库,跨服务器。
----------------------------------------------------------------------------
--Synonym在同一服务器上的不同数据库
use db_study
go
if object_id('MyCustomers')is not null drop synonym MyCustomers
go
--為表建立別名
Create Synonym MyCustomers For Northwind.dbo.Customers
--查詢
go
select * from mycustomers
--切換數據庫
use Northwind
go
--建立函數
if object_id('synonym_UF')is not null drop function synonym_UF
go
create function synonym_UF()
returns table
as
return(select * from Customers)
go
----為函數建立別名
use db_study
go
if object_id('synonym_uf')is not null drop synonym synonym_uf
go
create synonym synonym_uf for Northwind.dbo.synonym_UF
go
--調用函數
select * from synonym_uf()
--建立存儲過程
if object_id('synonym_PRO')is not null drop proc synonym_PRO
go
create proc synonym_PRO
as
select * from Customers
go
----為存儲建立別名
use db_study
go
if object_id('synonym_PRO')is not null drop synonym synonym_PRO
go
create synonym synonym_PRO for Northwind.dbo.synonym_PRO
go
--執行存儲過程
exec synonym_PRO
--同樣支持動態
if object_id('MyCustomers')is not null drop synonym MyCustomers
go
--為表建立別名
exec('Create Synonym MyCustomers For Northwind.dbo.Customers')
--查詢
go
select * from mycustomers
----------------------------------------------------------------------------
---Synonym在不同服务器上的不同数据库
--先建立鏈結服務器
--创建链接服务器
exec sp_dropserver 'ITSV', 'droplogins'
exec sp_addlinkedserver 'ITSV', ' ', 'SQLOLEDB', '192.168.12.***\wip'
exec sp_addlinkedsrvlogin 'ITSV ', 'false ',null, 'sa', 'sun*****%'
go
Create Synonym MyCustomers For ITSV.Northiwind.dbo.Customers
go
Select * from MyCustomers

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-298309-1-1.html 上篇帖子: sql的大全代码(1) 下篇帖子: SQL Server 2005 中文开发版 重装时报:对性能监视器计数器注册表值执行系统配置检查失败
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表