SQL中使用UNIQUE Cotraint还是Unique Index?_SQL SERVER数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

SQL中使用UNIQUE Cotraint还是Unique Index?[组图]

作者:黑客防线网安SQL维护基地 来源:黑客防线网安SQL维护基地 浏览次数:0

本篇关键词:组图还是使用一个
黑客防线网安网讯:  问题:   当我需要在表格中增加一个必须被唯一定义的柱状表时,发现SQL Server允许在一个柱状表上定义一个UNIQUE constraint。但是我也可以在柱状表上创造一个Unique Index。哪一个是...

  问题:

  当我需要在表格中增加一个必须被唯一定义的柱状表时发现SQL Server允许在一个柱状表上定义一个UNIQUE constraint但是我也可以在柱状表上创造一个Unique Index哪一个是我应该使用的?

  专家解答:

  这两种方法之间的不同是很微妙的UNIQUE constraints是ANSI SQL定义的一部分,定义UNIQUE constraints是数据库逻辑定义的一部分。另外,UNIQUE constraints作为一个副产品可以作为表格定义的一部分被创造,当约束被创造时SQL Server将自动的在搜索引擎下创造一个Unique Index。相反的,定义Unique Index是设计物理数据模型的一部分,他们不是ANSI标准。

  从性能立场上,UNIQUE constraints 和 unique indexes对最优化查询同样有效,这两个在使用过程中,你不会觉得其中一个比另一个更有效。在我看来,我坚持ANSI标准,通过约束实现柱体唯一性。在我看来UNIQUE constraints在更好的证明一个表格时有用,我使用它们超过unique indexes

  在一个Management Studio连接中,运行下列的程序去创造一个表格被叫做CAR。表格基于它的构成和模型定义一个UNIQUE constraint在CAR上。

  CREATETABLEdbo.CAR
  (
  CARIDINTIDENTITY(1,1)NOTNULL,
  MAKEVARCHAR(10)NOTNULL,
  MODELVARCHAR(10)NOTNULL,
  TOTALDOORSTINYINTNOTNULL,
  TOTALCYLINDERSTINYINTNOTNULL,
  CONSTRAINTPK_CARPRIMARYKEYNONCLUSTERED(CARID),
  CONSTRAINTUQ_CARUNIQUENONCLUSTERED(MAKE,MODEL)
  )
  GO

  运行SP_HELP CAR显示,the engine已经创造了包括这个约束和一个索引支持在内。

图一:运行SP_HELP CAR

  一个要求出现在我的桌面上。以报告为目的,管理想要通过year made跟踪cars,另外,对结构和模型。我们将改变这个表格使之包含一个年柱。

  ALTERTABLEDBO.CAR
  ADD[YEAR]SMALLINT
  GO

  增加这个柱体要求我去改变约束的唯一性,否则,我将无法通过结构和模型而不管年柱增加比一个多的car。另外,不允许通过结构,模型和年柱复制cars可能是一个好的主意。结果是我将重新创作这个约束的Unique Index去包含年柱。

  DROPINDEXDBO.CAR.UQ_CAR
  GO
  CREATEUNIQUEINDEXUQ_CARONDBO.CAR(MAKE,MODEL,[YEAR])
  GO

  运行上方的代码,你将看见随后的错误提示:

图二:错误提示

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-9760-1.html
网站维护教程更新时间:2012-03-21 02:25:31  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer