CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  基础类

为什么书里的数据表都可以设置两个“主键”,菜鸟在设置时老是不行,请指教!

楼主stone565(石头)2003-08-04 02:04:03 在 MS-SQL Server / 基础类 提问

各位前辈,菜鸟在书里和打开某样本数据库的数据表时,都可以看到几把亮黄色的'钥匙',但是,在自己的数据表只能设置一把‘钥匙’,别笑,菜鸟恳请各位指教了!*_* 问题点数:20、回复次数:9Top

1 楼shixueli(我们总是不能随心所欲)回复于 2003-08-04 05:02:11 得分 1

书上的是联合主键Top

2 楼shixueli(我们总是不能随心所欲)回复于 2003-08-04 05:06:40 得分 3

设置方法是按住ctrl键选中多个字段右键-设置主键即可Top

3 楼arrow_gx(8088的脑袋)回复于 2003-08-04 08:25:02 得分 1

同意楼上的,来晚了Top

4 楼flying120(飞侠)回复于 2003-08-04 09:15:55 得分 4

联合主键,设置时需确定所需设置的字段值不能为空,并且几个字段组合能确定唯一值,  
  设置方法是按住ctrl键选中多个字段右键-设置主键即可Top

5 楼stone565(石头)回复于 2003-08-04 11:12:36 得分 0

谢谢,楼上几位,帮菜鸟解答,还有一个问题,这些联合主键是不是都真正的‘主键’?Top

6 楼zhonghua79(中华)回复于 2003-08-04 14:19:25 得分 1

同意楼上的说法!!  
   
  Top

7 楼Dragonraja(璇)回复于 2003-08-04 14:49:50 得分 4

联合主键  
  例如:username,userage,userid  
  当三个同时作为主键时才是主键。  
  如果只是一个或两个就不是主键~~Top

8 楼pengdali()回复于 2003-08-04 15:01:35 得分 6

符合主键就是说:由两或多个个列同时组成这个表的主键  
   
   
   
  簇集索引=聚集索引:  
  聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。  
   
  聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节省成本。  
   
  非簇集索引:  
  非聚集索引与聚集索引一样有   B   树结构,但是有两个重大差别:    
   
  数据行不按非聚集索引键的顺序排序和存储。  
   
   
  非聚集索引的叶层不包含数据页。    
  相反,叶节点包含索引行。每个索引行包含非聚集键值以及一个或多个行定位器,这些行定位器指向有该键值的数据行(如果索引不唯一,则可能是多行)。  
   
  非聚集索引可以在有聚集索引的表、堆集或索引视图上定义。在   Microsoft®   SQL   Server™   2000   中,非聚集索引中的行定位器有两种形式:    
   
  如果表是堆集(没有聚集索引),行定位器就是指向行的指针。该指针用文件标识符   (ID)、页码和页上的行数生成。整个指针称为行   ID。  
   
   
  如果表没有聚集索引,或者索引在索引视图上,则行定位器就是行的聚集索引键。如果聚集索引不是唯一的索引,SQL   Server   2000   将添加在内部生成的值以使重复的键唯一。用户看不到这个值,它用于使非聚集索引内的键唯一。SQL   Server   通过使用聚集索引键搜索聚集索引来检索数据行,而聚集索引键存储在非聚集索引的叶行内。    
  由于非聚集索引将聚集索引键作为其行指针存储,因此使聚集索引键尽可能小很重要。如果表还有非聚集索引,请不要选择大的列作为聚集索引的键。  
   
   
  唯一索引:  
  唯一索引可以确保索引列不包含重复的值。在多列唯一索引的情况下,该索引可以确保索引列中每个值组合都是唯一的。  
  唯一索引既是索引也是约束。  
   
  复合索引:  
  索引项是多个的就叫组合索引,也叫复合索引。  
  复合索引使用时需要注意索引项的次序。Top

9 楼jacobran()回复于 2003-08-04 21:12:29 得分 0

同意楼上的,来晚了Top

相关问题

  • .net菜鸟问题:我的dataGrid怎么连上数据表?
  • 菜鸟妹妹问 关于 数据表 行列转换 显示
  • 菜鸟提问:对两格数据表操作问题
  • 菜鸟求教!怎样将查询数据表的结果保存为新表!
  • 菜鸟送分!怎样读取数据表的首记录和尾记录?
  • 菜鸟问题,存储过程中如何返回一个 一个数据表
  • 菜鸟的疑问?DELPHI的ADO控件远程访问SQL SERVER 2000的数据表
  • 菜鸟问题在线等待立即给分(Parapox数据表问题)急!!急!!急!!!
  • 菜鸟求救,建treeview(两层,是两个数据表),如何在程序中递归实现呢???????????
  • 关于获取数据表中主键的问题

关键词

  • 字段
  • 数据
  • 指针
  • 物理
  • 排序
  • 查询
  • 联合
  • 索引
  • 聚集
  • 主键

得分解答快速导航

  • 帖主:stone565
  • shixueli
  • shixueli
  • arrow_gx
  • flying120
  • zhonghua79
  • Dragonraja
  • pengdali

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo