首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql主键自动创建索引

基础概念

MySQL中的主键(Primary Key)是表中的一个或多个字段,用于唯一标识表中的每一行数据。主键具有以下特性:

  1. 唯一性:主键的值必须是唯一的,不能有重复。
  2. 非空性:主键的值不能为空。
  3. 唯一索引:MySQL会自动为主键创建一个唯一索引,以提高查询效率。

相关优势

  1. 唯一性保证:主键确保每一行数据的唯一性,避免了数据重复的问题。
  2. 快速查询:由于主键自动创建了唯一索引,查询主键字段的速度非常快。
  3. 数据完整性:主键的非空性保证了数据的完整性,避免了空值的出现。

类型

MySQL中的主键可以是以下几种类型:

  1. 单字段主键:一个单独的字段作为主键。
  2. 复合主键:多个字段组合成一个主键。
  3. 自增主键:使用AUTO_INCREMENT属性的整数字段作为主键,系统会自动为该字段生成唯一的值。

应用场景

  1. 用户表:用户的唯一标识符(如用户ID)可以作为主键。
  2. 订单表:订单的唯一标识符(如订单ID)可以作为主键。
  3. 产品表:产品的唯一标识符(如产品ID)可以作为主键。

遇到的问题及解决方法

问题:为什么MySQL主键自动创建索引?

原因:MySQL为了提高查询效率,自动为主键创建唯一索引。因为主键具有唯一性,索引可以帮助快速定位到特定的行数据。

解决方法:无需手动创建索引,MySQL会自动处理。

问题:如何查看表的主键和索引?

解决方法

代码语言:txt
复制
-- 查看表的主键
SHOW KEYS FROM table_name WHERE Key_name = 'PRIMARY';

-- 查看表的所有索引
SHOW INDEX FROM table_name;

问题:如何修改主键?

解决方法

代码语言:txt
复制
-- 删除旧的主键
ALTER TABLE table_name DROP PRIMARY KEY;

-- 添加新的主键
ALTER TABLE table_name ADD PRIMARY KEY (new_primary_key_column);

示例代码

假设有一个用户表users,结构如下:

代码语言:txt
复制
CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL UNIQUE
);

查询主键和索引

代码语言:txt
复制
-- 查看主键
SHOW KEYS FROM users WHERE Key_name = 'PRIMARY';

-- 查看所有索引
SHOW INDEX FROM users;

修改主键

代码语言:txt
复制
-- 删除旧的主键
ALTER TABLE users DROP PRIMARY KEY;

-- 添加新的主键
ALTER TABLE users ADD PRIMARY KEY (username);

参考链接

通过以上信息,你应该对MySQL主键自动创建索引的概念、优势、类型、应用场景以及常见问题有了全面的了解。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

mysql 联合主键_Mysql 创建联合主键

Mysql 创建联合主键 2008年01月11日 星期五 下午 5:21 使用primary key (fieldlist) 比如: create table mytable ( aa int, bb...char(8), cc date, primary key (aa,bb ) ); aa,bb为联合主键 不知道是不是因为mysql(6.0)的版本问题,还是各版本都是这种情况,mysql创建联合主键...TABLE t1( id … MySQL创建主键 如下: CREATE TABLE `loginlog` ( `id` ) unsigned zerofill NOT NULL AUTO_INCREMENT...涉及的知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/A … SQL Server中的联合主键、聚集索引、非聚集索引mysql...联合索引 我们都知道在一个表中当需要2列以上才能确定记录的唯一性的时候,就需要用到联合主键,当建立联合主键以后,在查询数据的时候性能就会有很大的提升,不过并不是对联合主键的任何列单独查询的时候性能都会提升

8.3K20
  • 主键索引就是聚集索引MySQL 索引类型大梳理

    之前松哥在前面的文章中介绍 MySQL索引时,有小伙伴表示被概念搞晕了,主键索引、非主键索引、聚簇索引、非聚簇索引、二级索引、辅助索引等等,今天咱们就来捋一捋这些概念。 1....前面两个例子中都有主键索引创建方式,我这里就不再列举了。...全文索引MySQL 中支持的版本也需要大家留意一下: MySQL 5.6 以前的版本,只有 MyISAM 存储引擎支持全文索引。...MySQL 的全文索引最开始只支持英文,因为英文分词比较方便;中文分词就比较麻烦,所以最早的 MySQL 全文索引是不支持中文的。...当我们基于 InnoDB 引擎创建一张表的时候,都会创建一个聚集索引,每张表都有唯一的聚集索引: 如果这张表定义了主键索引,那么这个主键索引就作为聚集索引

    2.3K20

    mysql创建索引

    1、索引需要占用磁盘空间,因此在创建索引时要考虑到磁盘空间是否足够 2、创建索引时需要对表加锁,因此实际操作中需要在业务空闲期间进行 SELECT * FROM table_name WHERE...在已存在的表中,可以使用ALTER TABLE语句或者CREATE INDEX语句创建索引 在已存在的表中,索引创建语句结构 1.普通索引(Normal): ALTER TABLE 表名 ADD INDEX...not null,等价于主键索引 3.单列索引: ALTER TABLE 表名 ADD INDEX 索引名(列名); 或 CREATE INDEX 索引名 ON 表名(列名); 4.组合索引: ALTER...); 或 CREATE SPATIAL INDEX 索引号 ON 表名(列名); 7.主键索引:即主索引,根据主键pk_clolum(length)建立索引,不允许重复,不允许空值; ALTER TABLE...大家可以尝试自己添加一下 删除索引语句结构 删除索引的语句方式主要有以下两种 删除主键索引 alter table 表名 drop primary; 其他索引的删除 ALTER TABLE 表名 DROP

    3.7K40

    mysql 唯一索引_mysql主键和唯一索引的区别

    Mysql索引大概有五种类型: 普通索引(INDEX):最基本的索引,没有任何限制 唯一索引(UNIQUE):与”普通索引”类似,不同的就是:索引列的值必须唯一,但允许有空值。...联合(组合)索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。 这里我们来看下唯一索引。...之前我们看了主键索引,他是一种特殊的唯一索引,二者的区别是,主键索引不能有空值,但是唯一索引可以有空值。...一:基本使用 1:唯一索引可以是单列,也可以是多列,下面我们来看下创建语句: # 创建单列唯一索引 alter table sc add unique (name); # 创建多列唯一索引 alter...但是,唯一性约束所在的列并不是表的主键列。 3:唯一性约束强制在指定的列上创建一个唯一性索引。在默认情况下,创建唯一性的非聚簇索引,但是,也可以指定所创建索引是聚簇索引

    2.8K30

    MySQL InnoDB创建索引

    聚簇索引创建方式一般有三种: 用户定义了主键,那么InnoDB依据主键创建聚簇索引 用户没有定义主键,那么InnoDB根据表上的第一个唯一非空的列创建聚簇索引 如果以上两条都不符合,那么InnoDB会自动指定一个系统列作为聚簇索引...,若用户既没有定义主键,也没有符合要求的唯一非空列,则InnoDB使用DB_ROW_ID作为主键创建聚簇索引。...=InnoDB; step1: 无论如何,聚簇索引都是会在第一步产生的,这里我们没有定义主键,也,没有定义唯一非空列,所以只能让InnoDB自动创建聚簇索引。...2.2 重启后创建索引 MySQL重启后,内部索引对象丢失,需要在启动后重新创建相关的索引MySQL重启后首先会将数据字典内的信息进行读取和初始化,然后根据数据字典的信息进行索引创建。...还是以上文的表t为例,假设现在MySQL重启,如何在t上构建索引? step1: 创建聚簇索引 无论如何,聚簇索引都会第一个创建

    5.7K30

    MySQL ORDER BY主键id加LIMIT限制走错索引

    背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49的时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...,大于49时就走PRIMARY主键索引。...在order by 主键id时,limit值的大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体的规则究竟是怎样。...由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引; order by 和 limit 结合使用,如果where 字段,order by字段都是索引,那么有limit索引会使用...查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysql的slow_query_log,及时做排查优化。

    1.8K10

    MySQL 创建索引索引效率验证

    给数据表创建索引 使用 create index 索引名 on 表名(字段名称(长度)); 来创建索引。 如果指定的字段类型是字符串,需要指定长度,建议长度与数据表中定义字段时的长度一致。...创建索引后,查看索引,可以看到刚创建索引信息。 5. 删除索引 使用 drop index 索引名 on 表名; 来删除索引。...开启 MySQL 运行时间监测 使用 set profiling=1; 开启 MySQL 运行时间检测,通过运行时间来对比有无索引的效率。...开启运行时间检测后,数据库操作的运行时间会保存在 information_schema 数据库的 profiling 表中,如果退出数据库连接,profiling 表中的数据会被自动删除。...创建索引后查询 上面已经将刚才创建索引删掉了,现在重新创建索引,然后执行相同的查询语句。 ? 从查询结果下面的时间可以看到是0.00秒,所以说这个时间的精度不够,需要使用更精确的监测时间来查看。

    3K30

    oracle删除主键索引的sql语句_oracle主键索引和普通索引

    for enforcement of unique /primary key 这个错误,对应的中文提示“ORA-02429: 无法删除用于强制唯一/主键索引”,其实从错误提示信息已经很明显了。...ORA-02429错误的原因是因为用户试图删除一个用于强制唯一/主键索引,解决方法也很简单,删除对应的约束就会自动删除该索引。...at line 1: ORA-02429: cannot drop index used for enforcement of unique/primary key 解决方法: 删除对应的约束就会自动删除该索引...&设置某一字段可以为null 1.oracle主键修改 1.1)首先查看需要修改的表的主键名,默认的情况下,数据库会自动分配 select * from user_cons_columns where...1.2)删除主键约束 alter table 表名 drop constraint 主键名(通过上一步查找出来) 1.3)添加主键约束 alter table 表名 add constraint 主键

    3.9K10

    oracle创建索引的sql语句_mysql创建组合索引

    创建索引一般分为在线索引和非在线索引,在线与非在线的区别:非在线锁表,优先创建索引,此时DML都被阻塞,所以快;相反,在线锁的是行而非表,通过临时表进行索引创建,所以不会影响DML操作,但副作用就是慢...如果在生产环境操作,不停服务的话,势必导致创建索引期间仍有DML操作进来。另外如果是大表,那么采用非在线而导致锁表所带来的影响可能会很大。一句话,生产环境不停服的脚本操作,建议使用online。...1、创建索引。...LOAD_ID, LOAD_STATUS, FACILITY_RRN) tablespace TBS_MY_INDEX pctfree 10 initrans 2 maxtrans 255; 2、创建在线索引...DROP INDEX 索引名; 4、查看某个表的索引,表名需大写。 SELECT * FROM ALL_INDEXES WHERE TABLE_NAME = '表名' 5、查看某个表哪些列有索引

    3.8K20

    MySQL ORDER BY主键id加LIMIT限制走错索引

    背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49的时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...,大于49时就走PRIMARY主键索引。...在order by 主键id时,limit值的大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体的规则究竟是怎样。...由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引; 对于数据量比较大,而且执行量很高的分页sql,尽可能将所有的查询字段包括在索引中,同时使用索引来消除排序; 多用explain...查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysql的slow_query_log,及时做排查优化。

    6.7K32

    mysql创建索引的原则

    mysql中使用索引的原则有以下几点: 1、 对于查询频率高的字段创建索引; 2、 对排序、分组、联合查询频率高的字段创建索引; 3、 索引的数目不宜太多 原因:a、每创建一个索引都会占用相应的物理控件...StudentName, Sex, Address, Phone, BirthDate),其中需要对StudentNo,StudentName字段进行查询,对Sex字段进行分组,对BirthDate字段进行排序,此时可以创建多列索引...index index_name (StudentNo, StudentName, Sex, BirthDate); #index_name为索引名 在上面的语句中只创建了一个索引...创建多列索引,需要遵循BTree类型, 即第一列使用时,才启用索引。...在上面的创建语句中,只有mysql语句在使用到StudentNo字段时,索引才会被启用。

    2.6K10

    MySQL 如何创建索引及优化

    4.找DBA或者运维对MySQL进行服务器的参数调优。 三、什么是索引MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。...const: 针对主键或唯一索引的等值查询扫描,最多只返回一行数据。 const 查询速度非常快, 因为它仅仅读取一次即可。...mysql 在查询时具体使用了哪些索引,由 key 字段决定。 6.key 此字段是 mysql 在当前查询时所真正使用到的索引。...*,o.* from user_info u LEFT JOIN  order_info o on u.id=o.user_id; 执行结果,type有ALL,并且没有索引: 开始优化,在关联列上创建索引...六、是否需要创建索引索引虽然能非常高效的提高查询速度,同时却会降低更新表的速度。实际上索引也是一张表,该表保存了主键索引字段,并指向实体表的记录,所以索引列也是要占用空间的。

    3.2K20

    主键、聚集索引、辅助索引

    如果在创建表时没有显式地定义主键,InnoDB 存储引擎会按如下方式选择或创建主键: 首先判断表中是否有非空的唯一索引(Unique NOT NULL),如果有,则该列即为主键 如果不符合上述条件,InnoDB...存储引擎自动创建一个 6 字节大小的指针 _rowid 作为主键 那如果表中有多个非空唯一索引时怎么办呢?...并且 InnoDB 中哈希索引是自适应的,也就是说 InnoDB 存储引擎会根据表的使用情况自动为表生成哈希索引,不能人为干预是否在一张表中生成哈希索引。 全文索引本文先暂且不做赘述。...一张表只能有一个主键,并且也只能有一个聚集索引,聚集索引还是按照主键来构建的,那这种种迹象不都表明主键就是聚集索引? 事实上,主键索引就不是一个层次的东西!...而至于 “主键就是索引” 这种观点的由来,是因为:InnoDB 存储引擎中,每张表都一定存在主键(显示或隐式),而聚集索引依赖于主键的建立,所以如果没有强制指定使用非聚集索引,InnoDB 在创建主键的同时会建立一个唯一的聚集索引

    80410

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券