SqlServer主键

本文介绍了数据库表中主键的设计原则,包括主键的作用、特点、选用策略及注意事项。重点讲解了业务主键与逻辑主键的区别,并给出了选择主键列的具体建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

*主键

作用:唯一标识表中的一条记录。

*特点:

1不能重复的列。

2主键不能为null

*同名时如何处理:洋(大) 洋(小)

*主键有两种选用策略:

业务主键和逻辑主键。

业务主键是使用有业务意义的字段做主键,比如身份证号、银行账号等;

逻辑主键是使用没有任何业务意义的字段做主键,完全给程序看的,业务人员不会看的数据。因为很难保证业务主键不会重复(身份证号重复)、不会变化(帐号升位),因此推荐用逻辑主键。

*选择什么样的列作为主键:

1.不允许为空的列。

2.没有重复的列。

3.与实际业务没有关系的列(逻辑主键)

4.稳定的列。(列中保存的数据不经常改变)

5.选择单列作为主键。(当通过多列共同唯一标识表中一条记录的时候,此时可以选择多列来工作组成一个主键,这种主键叫做:组合主键、复合主键、联合主键)一般不推荐使用组合主键。

6.尽量选择数字类型作为主键,不要选择字符串,或者数据类型比较大的列作为主键。(选择数据量比较小的列作为主键)

*当创建完毕一张表的时候,可以不设主键吗?

可以。但是建议每张表都应该有一个主键。

7.常见问题:

创建一个没有主键的表,插入数据,使用设计器删除时的问题。 如果没有主键,有重复数据,则删除、更新的时候会有问题。但通过Sql语句来执行则可以。

 

 

转载于:https://www.cnblogs.com/hao-1234-1234/p/6181082.html

### SQL Server 中主键的使用和配置 #### 创建带有主键的表格 在创建新表时,可以通过定义 `PRIMARY KEY` 来指定某个列为该表的主键。下面是一个简单的例子: ```sql CREATE TABLE Employees ( EmployeeID int NOT NULL, FirstName varchar(255), LastName varchar(255), BirthDate date, CONSTRAINT PK_Employees PRIMARY KEY (EmployeeID) ); ``` 这段代码创建了一个名为 `Employees` 的表,并设定了 `EmployeeID` 列作为其主键[^1]。 #### 修改现有表以添加主键约束 如果已经存在一张没有设置主键的表,则可通过 `ALTER TABLE` 命令来增加主键约束: ```sql ALTER TABLE Employees ADD CONSTRAINT PK_Employees PRIMARY KEY (EmployeeID); ``` 此语句会向已有的 `Employees` 表中加入一个名称为 `PK_Employees` 的主键约束到 `EmployeeID` 字段上。 #### 删除主键约束 当不再需要某张表上的主键约束时,也可以利用 `ALTER TABLE` 和 `DROP CONSTRAINT` 关键字组合来进行移除操作: ```sql ALTER TABLE Employees DROP CONSTRAINT PK_Employees; ``` 这行指令将会把之前设定于 `Employees` 表中的 `PK_Employees` 主键约束给取消掉。 #### 自增长主键(Identity) 有时希望主键能够自动递增,在这种情况下可以使用 `IDENTITY()` 函数来实现这一特性。例如: ```sql CREATE TABLE Orders ( OrderID int IDENTITY(1,1) PRIMARY KEY, ProductName nvarchar(50), Quantity smallint ); ``` 这里声明了 `OrderID` 是一个从 1 开始每隔一次加 1 的自增量整数型主键[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值