每张表都有一个什么索引,并且只有一个,一般都是在创建表时,为表创建主键时自主创建?

每张表都有一个什么索引,并且只有一个,一般都是在创建表时,为表创建主键时自主创建?,第1张

在MySQL数据库中,每张表都有一个主键,它是一种特殊的索引,用于唯一标识表中的每一行数据。通常,在创建表时,您会为表创建主键,并设置为自动递增,这样就能为每一行数据分配一个唯一的标识符。

主键不仅能用于唯一标识表中的每一行数据,还能提高查询效率。当你执行一条查询语句时,MySQL会使用主键索引来快速查找数据,从而提高查询效率。

除了主键,MySQL还支持其他类型的索引,包括普通索引、唯一索引和全文索引。普通索引用于提高查询效率,唯一索引用于保证表中每一行数据的唯一性,全文索引用于全文搜索。

索引主要用于提高查询效率,它能帮助MySQL快速查找数据,避免扫描整张表。使用索引时,需要注意,索引会增加表的大小,同时也会增加插入、更新和删除 *** 作的时间,因此需要合理使用索引。

1.外键的作用,主要有两个:

一个是让数据库自己通过外键来保证数据的完整性和一致性

一个就是能够增加ER图的可读性

2.外键的配置

1)先创建一个主表,代码如下:

#创建表student,并添加各种约束

create table student

(

id int primary key , #主键约束

name varchar(20) , #唯一约束

age int NOT NULL, #非空约束

sex varchar(2) ,

address varchar(20) default '重庆' #默认约束

)

再通过一个外键,创建一个分数表,这样的话,就可以方便查询。代码如下:

#创建分数表

create table score

(

id int primary key ,

sid int ,

china int ,

history int,

english int,

constraint FK_sid foreign key(sid) references student(id) #通过外键创建链接

)

创建外键的方法有很多,其中最常见创建外键的格式是:constraint FK_*** foreign key(**) references 链接的外表

删除外键:

alter table drop foreign key '外键名'.

注意:

只有在定义外键时,用constraint 外键名 foreign key .... 方便进行外键的删除

主键是唯一标示这一行的,就好像你的身份z号一样,每个人只有一个,也是唯一能证明你是你的东西。外键是别人执行你的东西。也就是说如果一个人想和你有点关系怎么办,那就要关联起来,怎么关联起来,就通过外键啊

定义主键和外键主要是为了维护关系数据库的完整性,总结一下:

一、主键是能确定一条记录的唯一标识,比如,一条记录包括身份正号,姓名,年龄。身份z号是唯一能确定你这个人的,其他都可能有重复,所以,身份z号是主键。

外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。

1.主键语法

①创建时:create table sc (

studentnoint,

courseidint,

scoreint,

primary key (studentno) )

②修改时:ALTER TABLE table_name ADD CONSTRAINT pk_name PRIMARY KEY(列名)

前提是原先没有设置主键。

2.外键语法

①创建时:create table sc (

studentnoint,

courseidint,

scoreint,

foreign key (courseid) )

②修改时:

ALTER TABLE news_info[子表名] ADD CONSTRAINT FK_news_info_news_type[约束名] FOREIGN KEY (info_id)[子表列] REFERENCES news_type[主表名] (id)[主表列]

3.使用组合主键

如果一列不能唯一区分一个表里的记录时,可以考虑多个列组合起来达到区分表记录的唯一性,形式

①创建时:create table sc (

studentnoint,

courseidint,

scoreint,

primary key (studentno,courseid) )

②修改时:alter table tb_name add primary key (字段1,字段2,字段3)

前提是原来表中没有设置主键,若原先已有主键则会报错。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7329764.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存