您现在的位置: 捷凌网安 >> 服务器 >> 数 据 库 >> MSSQL >> 正文
用SQL Server 2005同义字缩短开发时间

作者:佚名 责任编辑:左决 点击数: 更新时间:2008-3-11 0:45:46

同义字是SQL Server 2005的一个新对象。它为一个已经存在的对象建立一个别名。例如,如果你有一个名为SalesHistoryFromArchiveFiscalBusinessYear的表,你可以建立一个叫做Sales05的同义字指向那个对象。这意味着你不用写下面这个查询:

SELECT * FROM SalesHistoryFromArchiveFiscalBusinessYear2005

而只要用以下代码完成查询:

SELECT * FROM Sales05

优点

 前面的例子表明,你可以用同义字给名称较复杂的对象建立一个更加易懂的名称,从而简化数据库开发。

 同义字的主要优点在于,你可以用它在基本的对象和同义字间建立一个抽象层。例如,你可以建立一个名为SalesHistory的同义字,开发者在所有销售报告中都要用到它。这个同义字可以通过一个连接服务器引用一个本地视图或表,或一个远程视图或表。与数据复制组合使用时,这种同义字-对象关联可以成为一个非常强大的工具。下面的例子说明了这个问题。

实例

 由于业务和可扩展性需求不断扩张,你认为最好是把SalesHistory表从当前的Inventory数据库中删除,把它放到一个名为SalesData的独立数据库中。在Inventory数据库中有许多代码引用SalesHistory表。多数代码都是简单的查询,仅从SalesHistory表中读取数据。由于项目最终期限很快就临近,因此很难改变所有现有的代码,让其引用新数据库中的表。以下我来说明如何使用一个同义字显著缩短开发时间。

 假设你已经把SalesHistory表复制到新的SalesData数据库中,并对Inventory数据库中当前的SalesHistory表进行了重命名。(我总是喜欢首先重命名我打算删除的表。这使我有机会发现系统中由删除表造成的错误。)

 重命名SalesHistory表后,你可以建立一个引用你已经放到新数据库中的SalesHistory表的同义字。其脚本如下:

USE Inventory

GO

CREATE SYNONYM SalesHistory

FOR SalesData.dbo.SalesHistory;

GO

 这个同义字建立一个指向新SalesData数据库的SalesHistory表的指针;但是,因为同义字位于Inventory数据库中,且名为SalesHistory,那么,任何对SalesHistory同义字执行的查询或DML语句实际上是对SalesData数据库的SalesHistory表执行操作。

 Tim Chapman是肯塔基州路易维尔市一家银行的SQL Server数据库管理员,他有超过7年的IT行业经验。他还通过了微软SQL Server 2000和SQL Server 2005的认证

  • 上一篇文章:

  • 下一篇文章:
  •  
    最进更新
    普通文章foxpro 更新源表05-05
    普通文章foxpro 让视图与数据源相连05-05
    普通文章foxpro 机动查询和数据输入05-05
    普通文章foxpro 多个本地数据05-05
    普通文章foxpro 维护源表05-05
    普通文章Oracle 10g Release2新功能之05-05
    普通文章将Oracle 10g内置的安全特性05-05
    普通文章ACCESS 2003 建立数据库视频05-05
    普通文章三种SQL分页法效率分析05-05
    普通文章优化MySQL数据库查询的三种方05-05
     
    推荐文章
    推荐文章教你怎样在MySQL中提高全文搜05-05
    推荐文章SQL Server中数据导入导出三05-05
    推荐文章缓冲技术提高JSP程序的性能和04-17
    推荐文章asp去除HTML标记的三个实用函04-17
    推荐文章何时使用DataGrid、DataList04-17
    推荐文章MySQL存储过程示例04-14
    推荐文章华硕搭建Exchange2007企业邮03-14
    推荐文章升级Win 2003到Windows 200803-14
    推荐文章windows Server 2003 搭建域03-14
    推荐文章服务器成为IT中心的6个理由03-11
     
    热点文章 
    普通文章SQL Server 2008分析服务概览05-01
    普通文章Dlink路由器VPN设置04-29
    推荐文章缓冲技术提高JSP程序的性能和04-17
    普通文章教你优化你的ASP程序04-17
    推荐文章asp去除HTML标记的三个实用函04-17
    普通文章ASP添加验证码的解决方法04-17
    推荐文章何时使用DataGrid、DataList04-17
    普通文章Asp.net中禁止用户多次登录04-17
    普通文章MySQL之表结构修改04-14
    推荐文章MySQL存储过程示例04-14

    | 设为首页 | 加入收藏 | 联系站长 | 广告服务 | 友情链接 | 版权申明 | 网站地图 |

    在线交流 捷凌网安主群:51649627
    Copyright 2007-2008 © 捷凌网安. All rights reserved.
    备案序号:蜀ICP备08001812号