MYSQL 创建索引

目录

自动索引

手动创建

主键索引

唯一索引

普通索引

创建复合索引

查看索引

删除主键


自动索引

如果我们为一张表添加主键约束、外键约束、唯一约束时,MYSQL会为对应的列自动创建一个索引。如果不指定任何约束时,MYSQL会自动为每一列生成一个索引并用ROW_ID进行标识。

手动创建

主键索引

主键索引有三种创建方式,分别是:

1.创建表时创建主键

-- 创建表的时候指定主键 create table t_pk1( id bigint PRIMARY KEY auto_increment, name varchar(20) ); desc t_pk1;

desc t_pk1 是查看 t_pk1表的索引信息

2.创建表时单独指定主键列

create table t_pk( id bigint auto_increment, name varchar(20), PRIMARY KEY(id) ); desc t_pk;

3.修改表中的列为主键索引

create table t_pk2( id bigint, name varchar(20) ); alter table t_pk2 add primary key (id); alter table t_pk2 modify id bigint auto_increment; desc t_pk2;

这是未添加之前的,每一列的信息

这是添加之后的,

唯一索引

创建唯一索引的方式有三种,和上面添加主键索引大致上是相同的,故只给出对应的代码部分。

1.创建表时创建唯一键

create table t_uk( id bigint primary key auto_increment, name varchar(20) unique ); desc t_uk;

2.创建表时单独指定唯一列

create table t_uk1( id bigint primary key auto_increment, name varchar(20), unique (name) ); desc t_uk1;

3.修改表中的列为唯一索引

create table t_uk2( id bigint primary key auto_increment, name varchar(20) ); alter table t_uk2 add unique (name); desc t_uk2;
普通索引

创建时机有:

  1. 创建表时,明确知道某些列频繁查询
  2. 随着业务不断发展,在版本迭代过程中添加索引

我们也可在MYSQL中查看索引信息

show index from t_pk1;

普通索引的三种创建方式和上面两种差不多,不过还是有一些不同的。

1.创建表的时候创建普通索引

create table t_index1( id bigint primary key auto_increment, name varchar(20) unique, sno varchar(20), index (sno) );

index 是创建索引的关键字,括号里是索引列

其中:主键索引用PRI表示,唯一索引用UMI表示,普通索引用MUL表示。

2.修改表中的列为普通索引

create table t_index2( id bigint primary key auto_increment, name varchar(20) unique, sno varchar(20) ); alter table t_index2 add index (sno);

3.单独创建索引并指定索引名

create table t_index3( id bigint primary key auto_increment, name varchar(20) unique, sno varchar(20) ); create index index_name on t_index3(sno);

创建复合索引

创建符合索引与创建普通索引语法相同,只不过是指定多个列,列与列之间用逗号隔开。

1.创建表时指定索引列

create table t_index4( id bigint primary key auto_increment, name varchar(20) unique, sno varchar(20), class_id bigint, index(sno, class_id) );

2.修改表中的列为复合索引

create table t_index5( id bigint primary key auto_increment, name varchar(20) unique, sno varchar(20), class_id bigint ); alter table t_index5 add index(sno, class_id);

3.单独创建索引并指定索引名

create table t_index6( id bigint primary key auto_increment, name varchar(20) unique, sno varchar(20), class_id bigint ); create index t_index5_sno_class_id on t_index5 (sno, class_id);
查看索引

查看索引的三种方式,在上面都有提到,现在可以进行一下总结

  1. show keys from 表名
  2. show index from表名
  3. desc表名
删除主键

主键索引

alter table表名 drop PRIMARY KEY;

第一次使用删除语句报错的原因是:由于自增列的错误,所以下面是先删除了自增属性,然后重新删除主键。

其他索引

alter table表名 drop index 索引名

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1125645.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Thinkphp和Laravel框架的流浪猫领养系统_ct8whxh8

目录 ThinkPHP与Laravel框架的流浪猫领养系统对比分析系统架构与开发效率功能模块设计数据库与性能优化安全性与社区支持部署与维护 项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理 ThinkPHP与Laravel框架的流浪猫领养系统对比分析 系统架构与开…

MySql 8.0安装教程(windows系统),全网最详细的教程

目录 前言安装步骤安装包下载 前言 MySQL数据库服务是一个完全托管的数据库服务,是目前比较流行的开源数据库来部署云原生应用程序,不管在企业开发,个人开发,学校做项目都是必备的一款工具,并且MySQL是开源的&#…

Tailwind CSS:告别传统CSS,拥抱原子化开发新时代

想象一下,你在开发一个项目时,不再需要为CSS命名而烦恼,不再需要频繁在HTML和CSS文件间切换,更不必担心样式冲突和重复代码——这一切都源于一个名为Tailwind CSS的工具类优先框架。 Tailwind CSS的核心理念是“功能类优先”&…

RK3576基于UVC协议USB摄像头配置指南,手把手教你搞定

瑞芯微RK3576芯片平台基于UVC协议,配置USB摄像头实现即插即用的适配采集功能。演示设备:触觉智能RK3576开发板Purple Pi OH2系统固件为:Buildroot2024其配套RK3576核心板,尺寸40.540.5mm,邮票孔封装,支持LP…

性能指标笔记

网络指标 TTFB Time to First Byte 衡量请求资源到响应第一个字节开始到达之间的时间,结合 网络 面吧的资源请求耗时,可以判断主要延迟在哪一层。 关于 Network 网络面板: Queued at:表示请求何时入队,如果是 HTTP/1…

Thinkphp和Laravel框架的海关出入口货物报关统筹管理系统_szdhjj06

目录摘要概述技术架构对比核心功能模块性能与安全优化实施效果与扩展性项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理摘要概述 ThinkPHP和Laravel框架在海关出入口货物报关统筹管理系统中的应用,展现了现代PHP框架在复杂业务场景下的…

ubuntu系统_每天定时23:00 定时关机_怎么实现

在Ubuntu系统中设置每天23:00定时关机,最可靠的方法是使用系统内置的 cron 服务。下面的表格汇总了实现步骤和关键要点,你可以快速了解整个过程。步骤核心操作说明/命令示例1. 编辑计划任务终端中输入 sudo crontab -e使用 sudo 获取root权限&#xff0c…

HTML 表单元素与 React 中的其他 DOM 元素有所不同

React 表单与事件 本章节我们将讨论如何在 React 中使用表单。 HTML 表单元素与 React 中的其他 DOM 元素有所不同,因为表单元素生来就保留一些内部状态。 在 HTML 当中&#xff0c;像 <input>, <textarea>, 和 <select> 这类表单元素会维持自身状态&…

2026年最好用的六大代理IP服务商推荐:IPIDEA、Decodo、Smartproxy、IPRoyal、SOAX、Oxylabs

一、IPIDEA&#xff1a;IPIDEA是一家面向企业级AI训练与数据采集场景的全球代理服务商&#xff0c;其技术架构以超1亿高质量代理IP组成的庞大资源池为核心&#xff0c;覆盖全球220多个国家和地区&#xff0c;提供动态/静态住宅代理、移动代理及数据中心代理等全类型服务。IPIDE…

indirectly_readable和indirectly_writable这两个核心概念的具体定义和使用场景是什么?

indirectly_readable 和 indirectly_writable 是 C20 中引入的两个核心概念&#xff0c;它们为迭代器操作提供了基础的类型安全约束&#xff0c;是理解现代 C 范围库和算法库的关键。 下面这个表格能帮你快速把握它们的核心区别&#xff1a;特性indirectly_readableindirectly_…

超绝好用清理软件工具,(附下载方式)超多好用功能

电脑用久了&#xff0c;难免会堆积闲置软件、捆绑程序&#xff0c;自带卸载工具往往 “卸不干净”&#xff0c;残留的文件碎片和注册表垃圾不仅占用磁盘空间&#xff0c;还可能拖慢系统运行。今天给大家实测推荐三款 Windows 平台口碑爆棚的卸载工具 ——HiBit Uninstaller、Ge…

数据库分片和分区

1.分片Database Sharding是一种 水平拆分&#xff08;Horizontal Partitioning&#xff0c;按行拆分&#xff09; 的方案&#xff0c;用来解决单机数据库在数据量、并发量上的瓶颈问题。&#xff08;垂直拆分是指按列的字段拆分。&#xff09;一句话定义&#xff1a;把同一张逻…

何为Transformer 架构?

何为Transformer 架构&#xff1f;最后 选择AI大模型就是选择未来&#xff01;最近两年&#xff0c;大家都可以看到AI的发展有多快&#xff0c;时代在瞬息万变&#xff0c;我们又为何不给自己多一个选择&#xff0c;多一个出路&#xff0c;多一个可能呢&#xff1f; 与其在传统…

HiBit Uninstaller全攻略:轻量无广,彻底告别软件残留(附下载方式)

一、软件简介&#xff1a;为何它能成为系统清理神器&#xff1f;HiBit Uninstaller是由HiBit Software开发的免费Windows系统卸载工具&#xff0c;自2017年发布以来&#xff0c;凭借轻量、高效、无广告的特性&#xff0c;在同类工具中脱颖而出&#xff0c;成为普通用户与IT维护…

电阻的基础知识

电阻与电容、电感一样都是最基本的元器件&#xff0c;大量使用于各种电气或电子设备中。对从事电气工作的人而言或许过于普通&#xff0c;平时忽视了它&#xff0c;但如果没有电阻&#xff0c;电气或电子电路就无法建立。电阻就是如此重要的元器件。 电阻的作用电阻是具有一定电…

jvm性能调优

JVM性能调优方法调整堆内存大小 -Xms和-Xmx参数分别设置JVM堆的初始大小和最大大小。建议将两者设为相同值以避免运行时动态调整带来的性能开销。例如&#xff1a; -Xms4g -Xmx4g 根据应用需求调整大小&#xff0c;避免频繁Full GC。选择合适的垃圾回收器 根据应用特点选择垃圾…

【光子AI】FastAPI 极简权威指南 (The Ultimate Minimalist Guide)

这是一个 FastAPI 深度极简教程。虽然篇幅受限于输出长度,但这篇指南涵盖了从入门到生产环境部署的核心知识体系,内容密度相当于一本 10,000 字的技术手册的精华浓缩版。 我们将从零开始,逐步构建一个现代化的、高性能的 Web API。 FastAPI 极简权威指南 (The Ultimate Min…

【光子AI】FastAPI 极简教程(从 0 到 生产级)

FastAPI 极简教程&#xff08;从 0 到 生产级&#xff09; 本教程面向 Python Web / 后端 / AI 工程师&#xff0c;目标是&#xff1a; 用最少的概念&#xff0c;建立正确的 FastAPI 心智模型从 0 写到 可上线的工程结构讲清楚 async / event loop / 并发模型 / 性能边界 全文偏…

mysql一条sql语句是如何运行的

MySQL SQL 语句执行流程MySQL 执行一条 SQL 语句的过程可以分为多个阶段&#xff0c;包括连接管理、解析与优化、执行引擎处理以及结果返回。以下是详细流程&#xff1a;连接管理客户端通过 TCP/IP 或 Unix Socket 连接到 MySQL 服务器。连接建立后&#xff0c;服务器进行身份验…

MySQL 8.0在windows环境安装及配置

文章目录 一、下载二、安装三、配置环境变量 一、下载 1、先彻底卸载之前的MySQL&#xff0c;并清理其 残留文件 。 2、登录网址https://www.mysql.com/ 3、点击网址左下角“中文”按钮&#xff0c;切换到中文界面 4、点击网页上方的“下载”按钮&#xff0c;然后点击网…