数据库:“主键”

Posted 葡萄籽-June

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据库:“主键”相关的知识,希望对你有一定的参考价值。

数据库☞主键

本文主要是根据对数据库的相应学习,并对数据库中的一个重要的知识点——主键 进行总结!
中间也会穿插其他的一些知识点,例如外键、关系型数据库吖等。



前言

主键的应用是很重要的,这对于数据库的设计十分重要!

关系型数据库总结—易理解!

泛型【在整理中~后贴哦】


一、概念

主键和外键是把多个表组织为一个有效的关系数据库的粘合剂。数据库模式从理论上的逻辑设计转换为实际的物理设计。而主键和外键的结构是这个设计过程的症结所在。

二、设计原则

关系数据库依赖于主键【它是数据库物理模式的基石】。
主键在物理层面上只有两个用途:
(1)惟一地标识一行。
(2)作为一个可以被外键有效引用的对象。

  • 原则1:主键应当是对用户没有意义的

其实从设计角度来说主键对用户无意义最好,为什么呢?
主键最主要的作用就是保证实体的完整性,加快数据库的操作速度。但往往在范式的规范下,有时候主键的组成不止由单属性组成,此时在操纵数据库中的数据时会比较麻烦 。
另外,有初学者会想,主键不是唯一么?主键也不能为空等等。很多时候简单的表格会以用户名这种作为主键,但是不要忘记当用户数量过于庞大时,会带来很多的麻烦,亦或者说,如果你想用唯一属性可以使用UNIQUE,而主键有时候有自增的功能可以省去很多的麻烦等等。

  • 原则2: 主键应该是单列的

就像我上一个原则里说的一样,主键有时候会由多属性组成,此时操作起来会出现很多问题(DuplicateKeyException…),主键应该是单列的以便提高连接和筛选操作的效率。

  • 原则3:永远也不要更新主键

主键在实际中是可以被更新的,但是设计的时候最好考虑的是不要更新主键。

  • 原则4:主键不应包含动态变化的数据

如时间戳、创建时间列、修改时间列等这些动态变化的数据不应该被定义为主键;主键是不可被直接修改的。


三、SQL定义主键约束(实体完整性)

在实例说明之前,先说一下主键的作用:

(1)保证实体的完整性;
(2)加快数据库的操作速度;
(3)在表中添加新记录时,DBMS会自动检查新记录的主键值,不允许该值与其他记录的主键值重复;
(4)DBMS自动按主键值的顺序显示表中的记录。如果没有定义主键,则按输入记录的顺序显示表中的记录。

栗子:(具体的e-r图等,在这篇文章☞关系型数据库总结—易理解!都有介绍,可以观看哦~)
读者表 Reader

/*
* 单属性:主键只有一个属性组成
*/
/*一、主键约束:列级完整性约束*/
CREATE TABLE m_reader
(
rno varchar(10) PRIMARY KEY,       --- 设置为主键 /*列级完整性约束条件*/
rname varchar(10) UNIQUE not NULL,  ---  不许取空值      
rgender varchar(4) DEFAULT '男'  CONSTRAINT consgender CHECK (sgender IN('男', '女')),							  ---  (下)设置默认值男,约束选项为男女
rtel  char(11),
rmajor  varchar(10),
rregist date,
rtype varchar(10),
FOREIGN KEY (rtype) REFERENCES m_readerType(rtype)
    ----(参照完整性)声明是什么表中的外键(m_readerType:读者类型表)
)




/*一、主键约束:表级完整性约束*/
CREATE TABLE m_reader
(
r_no varchar(10) NOT NULL,          --- 设置为主键 /*列级完整性约束条件*/
r_name varchar(10) UNIQUE not NULL,  ---  不许取空值      
r_gender varchar(4) DEFAULT '男'  CONSTRAINT consgender CHECK (sgender IN('男', '女')),							  ---  (下)设置默认值男,约束选项为男女
r_tel  char(11),
r_major  varchar(10),
r_regist date,
r_type varchar(10),
PRIMARY KEY (r_no),				  --- 设置为主键 /*表级完整性约束条件*/
FOREIGN KEY (r_type) REFERENCES m_readerType(r_type)
    ----(参照完整性)声明是什么表中的外键(m_readerType:读者类型表)
)





/*多属性:只能用表级完整性约束*/
---转换一下借阅表,将借阅编号暂删除。
CREATE TABLE m_borrow
(
b_time date ,          
b_num int , 
b_ReturnTime date,
r_no varchar(10),           		 --外键
b_no varchar(10),			    --外键
PRIMARY KEY (r_no,b_no),			--- 设置为主键 /*表级完整性约束条件*/表示由读者编号和图书编号共同决定了一次借阅信息。
FOREIGN KEY (r_no) REFERENCES m_reader(r_no),
FOREIGN KEY (b_no) REFERENCES m_book(b_no)
    ----(参照完整性)声明是什么表中的外键(m_book:图书信息表)
)

四、在不同的关系数据库中的主键选取策略

栗子:管理员表

(1)自动增长型字段

  • MySQL
/*
把表的主键设为auto_increment类型,数据库就会自动为主键赋值。
*/
CREATE TABLE m_user
(
m_id int auto_increment PRIMARY KEY NOT NULL,
m_name varchar(10) NOT NULL,       --- /*设置为主键,自增*/
m_password varchar(10) not NULL
)

insert into m_user values('name1','1234');
select m_id from m_user;

  • Oracle
/*
* 为每张表的主键创建一个单独的序列,然后从这个序列中获取自动增加的标识符,把它赋值给主键。
* 这个序列的起始值为1,增量为2
*/
create sequence m_name_seq increment by 2 start with 1;

CREATE TABLE m_user
(
m_id int PRIMARY KEY NOT NULL,
m_name varchar(10) NOT NULL,       --- /*设置为主键,自增*/
m_password varchar(10) not NULL
)
/*
curval:返回序列的当前值
nextval:先增加序列的值,然后返回序列值
*/
insert into m_user values(m_name_seq.nextval, 'name1','1234');
select m_id from m_user;
  • Sql Server
/*
如果把表的主键设为identity类型,数据库就会自动为主键赋值。
*/
CREATE TABLE m_user
(
m_id int identity(1,1) PRIMARY KEY NOT NULL,
m_name varchar(10)  PRIMARY KEY NOT NULL,       --- /*设置为主键,自增*/
m_password varchar(10) not NULL
)

insert into m_user values('name1','1234');
select m_id from m_user;

(2)手动增长型字段

在插入语句时,自定义主键字段插入相应类型的数据即可。

事实上,还有许多的主键选取策略,在这边不再深入总结。
上述的这些已经能够对主键有一个比较清晰的认识啦!

以上是关于数据库:“主键”的主要内容,如果未能解决你的问题,请参考以下文章

比较有用的php代码片段

代码周边MongoDB与Mysql对比以及插入稳定性分析(指定主键的影响)

大家一起撸代码之——Hibernate各种主键生成策略与配置详解

如何在实体框架代码优先数据库中手动设置实体主键?

部分代码片段

将代码片段插入数据库并在 textarea 中以相同方式显示