sql中使用unique constraint还是unique index?--

sql中使用unique constraint还是unique index?--

ID:22372346

大小:54.50 KB

页数:5页

时间:2018-10-28

sql中使用unique constraint还是unique index?--_第1页
sql中使用unique constraint还是unique index?--_第2页
sql中使用unique constraint还是unique index?--_第3页
sql中使用unique constraint还是unique index?--_第4页
sql中使用unique constraint还是unique index?--_第5页
资源描述:

《sql中使用unique constraint还是unique index?--》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、SQL中使用UNIQUEConstraint还是UniqueIndex?>>  问题:  当我需要在表格中增加一个必须被唯一定义的柱状表时,发现SQLServer允许在一个柱状表上定义一个UNIQUEconstraint。但是我也可以在柱状表上创造一个UniqueIndex。哪一个是我应该使用的?  专家解答:  这两种方法之间的不同是很微妙的,UNIQUEconstraints是ANSISQL定义的一部分,定义UNIQUEconstraints是数据库逻辑定义的一部分。另外,UNIQUEconstraints

2、作为一个副产品可以作为表格定义的一部分被创造,当约束被创造时SQLServer将自动的在搜索引擎下创造一个UniqueIndex。相反的,定义UniqueIndex是设计物理数据模型的一部分,他们不是ANSI标准。  从性能立场上,UNIQUEconstraints和uniqueindexes对最优化查询同样有效,这两个在使用过程中,你不会觉得其中一个比另一个更有效。在我看来,我坚持ANSI标准,通过约束实现柱体唯一性。在我看来UNIQUEconstraints在更好的证明一个表格时有用,我使用它们超过uniq

3、ueindexes  在一个ManagementStudio连接中,运行下列的程序去创造一个表格被叫做CAR。表格基于它的构成和模型定义一个UNIQUEconstraint在CAR上。  CREATETABLEdbo.CAR  (  CARIDINTIDENTITY(1,1)NOTNULL,  MAKEVARCHAR(10)NOTNULL,  MODELVARCHAR(10)NOTNULL,  TOTALDOORSTINYINTNOTNULL,  TOTALCYLINDERSTINYINTNOTNULL,  C

4、ONSTRAINTPK_CARPRIMARYKEYNONCLUSTERED(CARID),  CONSTRAINTUQ_CARUNIQUENONCLUSTERED(MAKE,MODEL)  )  GO  运行SP_HELPCAR显示,theengine已经创造了包括这个约束和一个索引支持在内。  图一:运行SP_HELPCAR  一个要求出现在我的桌面上。以报告为目的,管理想要通过yearmade跟踪cars,另外,对结构和模型。我们将改变这个表格使之包含一个年柱。  ALTERTABLEDBO.CAR  AD

5、D[YEAR]SMALLINT  GO  增加这个柱体要求我去改变约束的唯一性,否则,我将无法通过结构和模型而不管年柱增加比一个多的car。另外,不允许通过结构,模型和年柱复制cars可能是一个好的主意。结果是我将重新创作这个约束的UniqueIndex去包含年柱。  DROPINDEXDBO.CAR.UQ_CAR  GO  CREATEUNIQUEINDEXUQ_CARONDBO.CAR(MAKE,MODEL,[YEAR])  GO  运行上方的代码,你将看见随后的错误提示:  图二:错误提示  伙计,这个看

6、起来丑陋吧。DROP失败是因为约束依靠索引,它必须匹配约束的定义。在我们的例子中去改变唯一性,我们可以先drop然后重复增加约束。  ALTERTABLEDBO.CAR  DROPCONSTRAINTUQ_CAR  GO  ALTERTABLEDBO.CAR  ADDCONSTRAINTUQ_CARUNIQUE(MAKE,MODEL,[YEAR])  GO  重新运行SP_HELPCAR,显示有改变在进行。  图三:第二次运行SP_HELPCAR  我刚刚注意到在表格上没有clusteredindex。自从我们

7、的所有报告将按照结构,模型和年柱分类,我就想将uniqueconstraint转化为clusteredindex。同时你又可以DROP以及CREATE这个约束使它成为UNIQUECLUSTERED,实际上你也可以使用CREATEINDEX使用DROP_EXISTING选项。自从约束的约束匙不再改变,SQLServerengine将允许你去发行下列的的声明,将UNIQUEconstraint改变为clustered。  CREATEUNIQUECLUSTEREDINDEXUQ_CARONDBO.CAR(MAKE,

8、MODEL,[YEAR])  WITHDROP_EXISTING  GO  再次运行SP_HELPCAR显示constraint'sindex被改变成clusteredindex  图四:第三次运行SP_HELPCAR>>>>这篇文章来自..,。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。