睡个懒觉 發表於 2023-10-16 00:00:00

主键与聚集索引

<p>
        <strong>主键(PRIMARY KEY )</strong><br>
        来自MSDN的描述:<br>
        表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键。<br>
        一个表只能有一个 PRIMARY KEY 约束,并且 PRIMARY KEY 约束中的列不能接受空值。由于 PRIMARY KEY 约束可保证数据的唯一性,因此经常对标识列定义这种约束。<br>
        如果为表指定了 PRIMARY KEY 约束,则 SQL Server 2005 数据库引擎 将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。<br>
        创建主键时,数据库引擎 会自动创建唯一的索引来强制实施 PRIMARY KEY 约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施 <strong>PRIMARY KEY 约束。</strong><br>
        聚集索引<br>
        聚集索引基于数据行的键值在表内排序和存储这些数据行。每个表只能有一个聚集索引,因为数据行本身只能按一个顺序存储。<br>
        每个表几乎都对列定义聚集索引来实现下列功能:<br>
        可用于经常使用的查询。<br>
        提供高度唯一性。<br>
        两者的比较<br>
        下面是一个简单的比较表 </p>
<table border="1" cellpadding="0" cellspacing="0" width="600"><tbody>
<tr>
<td valign="top" width="151">
                                <p>
                                         </p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        <strong>主键</strong></p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        <strong>聚集索引</strong></p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                        用途</p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        强制表的实体完整性</p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        对数据行的排序,方便查询用</p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                        一个表多少个</p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        一个表最多一个主键</p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        一个表最多一个聚集索引</p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                        是否允许多个字段来定义</p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        一个主键可以多个字段来定义</p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        一个索引可以多个字段来定义</p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                         </p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                         </p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                         </p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                        是否允许 null 数据行出现</p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        如果要创建的数据列中数据存在null,无法建立主键。<br>
                                        创建表时指定的 PRIMARY KEY 约束列隐式转换为 NOT NULL。</p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        没有限制建立聚集索引的列一定必须 not null .<br>
                                        也就是可以列的数据是 null<br>
                                        参看最后一项比较</p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                        是否要求数据必须唯一</p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        要求数据必须唯一</p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        数据即可以唯一,也可以不唯一。看你定义这个索引的 UNIQUE 设置。<br>
                                        (这一点需要看后面的一个比较,虽然你的数据列可能不唯一,但是系统会替你产生一个你看不到的唯一列)</p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                         </p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                         </p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                         </p>
                        </td>
                </tr>
<tr>
<td valign="top" width="151">
                                <p>
                                        创建的逻辑</p>
                        </td>
                        <td valign="top" width="194">
                                <p>
                                        数据库在创建主键同时,会自动建立一个唯一索引。<br>
                                        如果这个表之前没有聚集索引,同时建立主键时候没有强制指定使用非聚集索引,则建立主键时候,同时建立一个唯一的聚集索引</p>
                        </td>
                        <td valign="top" width="227">
                                <p>
                                        如果未使用 UNIQUE 属性创建聚集索引,数据库引擎 将向表自动添加一个四字节 uniqueifier 列。<br>
                                        必要时,数据库引擎 将向行自动添加一个 uniqueifier 值,使每个键唯一。此列和列值供内部使用,用户不能查看或访问。</p>
                        </td>
                </tr>
</tbody></table>
<p>
         </p>
頁: [1]
查看完整版本: 主键与聚集索引