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

Mysql 的Index 索引设置

索引是快速搜索的关键。MySQL索引的建立对于MySQL的高效运行是 很重要的。对于少量的数据,没有合适的索引影响不是很大,但是,当随着数据量的增加,性能会急剧 下降。...当创建索引带来的好处多过于消耗的时候,才是最优的选择~ # 查看索引 show index from quickchat_user_additional; 索引的类型 (具体设置在Navicat中添加即可...) 主键索引 PRIMARY KEY 它是一种特殊的唯一索引,(设置了主键底层就自动设置)了,不允许有空值。...MYSQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引。...例如: image.png 索引的存储结构 BTree索引(推荐) MySQL中普遍使用B+Tree做索引,也就是BTREE。

2K20
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL SQL优化之覆盖索引

内容概要 利用主索引提升SQL的查询效率是我们经常使用的一个技巧,但是有些时候MySQL给出的执行计划却完全出乎我们的意料,我们预想MySQL会通过索引扫描完成查询,但是MySQL给出的执行计划却是通过全表扫描完成查询的...前些天,有个同事跟我说:“我写了个SQLSQL很简单,但是查询速度很慢,并且针对查询条件创建了索引,然而索引却不起作用,你帮我看看有没有办法优化?”。...那为什么MySQL没有利用索引(uni_order_code)扫描完成查询呢?因为MySQL认为这个场景利用索引扫描并非最优的结果。我们先来看下执行时间,然后再来分析为什么没有利用索引扫描。...执行计划显示查询会利用覆盖索引,并且只扫描了1000行数据,查询的性能应该是非常好的。 执行时间:13ms ? 从执行时间来看,SQL的执行时间提升到原来的1/20,已经达到我们的预期。...要写出性能很好的SQL不仅需要学习SQL,还要能看懂数据库执行计划,了解数据库执行过程、索引的数据结构等。

1.7K60

MySQL索引SQL语句优化

在字段上计算不能命中索引, 10、强制类型转换会全表扫描,   如果phone字段是varcher类型,则下面的SQL不能命中索引。...13、建立索引的列不能为null,使用not null约束及默认值 14、利用延迟关联或者子查询优化超多分页场景, MySQL并不是跳过offset行,而是取offset+N行,然后放弃前offset...行,返回N行,那当offset特别大的时候,效率非常低下,要么控制返回的总数,要么对超过特定阈值的页进行SQL改写。...select id,name from product limit 866613, 20 使用上述SQL语句做分页的时候,可能有人会发现,随着表数据量的增加,直接使用limit分页查询会越来越慢。...SQL可以采用如下的写法:select id,name from product where id> 866612 limit 20。

1.6K10

MySQLMySQLSQL语句的索引分析

MySQLSQL语句的索引分析 了解过 索引 的概念以及 B+树 的概念之后,我们就来看看怎么分析一条查询语句的索引使用情况。...相信不少同学应该都使用过 EXPLAIN 来分析 SQL 语句,但是具体到 EXPLAIN 中每个字段的作用,可能有不少同学还是会有点晕的。...const 根据主键或唯一索引进行等值查询时,MySQL 发现能对查询条件优化成常数时,访问方法就是 const 。常数级别也就是速度非常非常快,常见于主键等值查询。...不过某些情况下,MySQL 的优化器在计算到走索引还不如走全表时,也会直接使用全表扫描,以后我们踫到这种问题了再单独拿出来说吧。...参考文档: 《MySQL是怎样运行的》

9810

MySQL SQL索引优化总结

专栏持续更新中:MySQL详解 首先我们需要知道MySQL主要是从以下3个方面进行优化: SQL语句和索引 应用优化(引入缓存、连接池) 配置参数优化 一、SQL语句和索引的优化 当数据量比较大,若SQL...语句写的不合适,会导致SQL的执行效率低,我们需要等待很长时间才能拿到结果 针对性优化的时候,若数据量太大,可通过limit分页 explain分析的时候可能出现以下问题: 没有用索引 用多列索引没有用到第一列...,导致没用到索引 联合查询的大小表设置不合理,导致索引没用上(小表是整表查询,大表才用索引) 多表查询不用in(产生中间表),用外连接替代带in子查询的过程,合理使用索引 二、应用优化 除了优化SQL索引...MySQL查询缓存 MySQL的查询缓存是把上一次select的查询结果记录下来放在缓存当中,下一次再查询相同内容的时候,直接从缓存中取出来就可以了,不用再进行一遍真正的SQL查询(在内存中划分一块空间用做缓存的地方...并发连接数量和超时时间 MySQL Server作为一个服务器,可以设置客户端的最大连接量和连接超时时间,如果数据库连接统计数量比较大,这两个参数的值需要设置大一些 在配置文件(my.cnf或my.ini

18950

SQL优化 MySQL版 – 索引分类、创建方式、删除索引、查看索引SQL性能问题

,我不光可以设置age,我也可以吧name设置索引,或许更多; 唯一索引 顾名思义,就是不能重复,比如age就不能被设置为唯一索引,因为年龄肯定是不唯一的,小明18岁,有可能小李也是18岁,这就重复了...,所以age这一列不能被设置成唯一索引; 一般唯一索引就是Id; 复合索引 由多个列构成,相当于书的二级目录,比如我找“赵”这个字,它就先去Z里面找,然后再去zhao里面去找,找两次; 这个时候我把name...explain,可以模拟SQL优化器执行SQL语句,从而让开发人员知道自己编写的状况; 查询执行计划:explain+SQL语句; 举例:explain select * From bbs_detail...key_len:实际使用索引的长度; ref:表和表之间的引用关系; rows:通过索引查询到的数据量; Extra:额外的优化信息 2.MySQL查询优化器会干扰我们的优化 我在前几章说过有关为什么会干扰我们优化好的...SQL语句,因为它内置有一个优化器,它会擅自篡改我们优化好的SQL语句;

1.2K10

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

创建索引一般分为在线索引和非在线索引,在线与非在线的区别:非在线锁表,优先创建索引,此时DML都被阻塞,所以快;相反,在线锁的是行而非表,通过临时表进行索引的创建,所以不会影响DML操作,但副作用就是慢...如果在生产环境操作,不停服务的话,势必导致创建索引期间仍有DML操作进来。另外如果是大表,那么采用非在线而导致锁表所带来的影响可能会很大。一句话,生产环境不停服的脚本操作,建议使用online。...1、创建索引。...DROP INDEX 索引名; 4、查看某个表的索引,表名需大写。 SELECT * FROM ALL_INDEXES WHERE TABLE_NAME = '表名' 5、查看某个表哪些列有索引。...SELECT * FROM ALL_IND_COLUMNS WHERE TABLE_NAME = '表名' 如果在where 子句中有OR 操作符或单独引用复合索引列的后面列则将不会走索引,将会进行全表扫描

3.7K20

Mysql中哪些Sql不走索引

要尽量避免这些不走索引sql: SELECT `sname` FROM `stu` WHERE `age`+10=30;– 不会使用索引,因为所有索引列参与了计算 SELECT `sname` FROM...` LIKE’金蝶%’ — 走索引 SELECT * FROM `houdunwang` WHERE `uname` LIKE “%金蝶%” — 不走索引 — 正则表达式不使用索引,这应该很好理解,所以这就是为什么在...SQL中很难看到regexp关键字的原因 — 字符串与数字比较不使用索引; CREATE TABLE `a` (`a` char(10)); EXPLAIN SELECT * FROM `a` WHERE...`a`=”1″ — 走索引 EXPLAIN SELECT * FROM `a` WHERE `a`=1 — 不走索引,同样也是使用了函数运算 select * from dept where dname...换言之,就是要求使用的所有字段,都必须建立索引,我们建议大家尽量避免使用or 关键字 — MySQL内部优化器会对SQL语句进行优化,如果优化器估计使用全表扫描要比使用索引快,则不使用索引

1.6K20

mysql索引abc,a=1 and c=2是否可使用索引_sql联合索引

在一次查询中,MySQL只能使用一个索引。 在真实项目中,SQL语句中的WHERE子句里通常会包含多个查询条件还会有排序、分组等。...MYSQL中常用的强制性操作(例如强制索引) https://www.jb51.net/article/49807.htm SELECT * FROM TABLE1 FORCE INDEX (FIELD1...bc 的时候用不到abc和ac 索引。...使用联合索引应该注意: MySQL使用联合索引只能使用左侧的部分,例如INDEX(a,b,c),当条件为a或a,b或a,b,c时都可以使用索引,但是当条件为b,c时将不会使用索引。...离散度更高的索引应该放在联合索引的前面,因为离散度高索引的可选择性高。考虑一种极端的情况,数据表中有100条记录,若INDEX(a,b)中a只有两种情况,而b有100种情况。

1.5K10

mysql 5.7 sql_mode设置问题

问题说明 在mysql较低版本中,对SQL语句并没有严格的限制检查,在5.7及以上版本开启严格模式,在插入数据的时候,如果字段没有设置默认值,则会报类似于这样的错误:“Field ‘title’ doesn...解决方法 1、查看sql_mode select @@sql_mode 查询出来的值为: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE...ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION 2、修改 my.ini(Windows平台)或my.cnf(Linux平台) sql_mode...NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' 在sql_mode...中去掉only_full_group_by 3、如果还是不成功,可以设置sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

1.1K21

mysql sql-mode 解析和设置

sql_mode:简而言之就是:它定义了你MySQL应该支持的sql语法,对数据的校验等等 select @@sql_mode:使用该命令我们可以查看我们当前数据库的sql_mode mysql> select...不设置此值时,用默认的存储引擎替代,并抛出一个异常 三、据说是MySQL5.0以上版本支持三种sql_mode模式:ANSI、TRADITIONAL和STRICT_TRANS_TABLES。 ...将当前数据库模式设置为ANSI模式:  mysql> set @@sql_mode=ANSI;   2、TRADITIONAL模式:严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不能插入...将当前数据库模式设置为TRADITIONAL模式: mysql> set @@sql_mode=TRADITIONAL;    3、STRICT_TRANS_TABLES模式:严格模式,进行数据的严格校验...将当前数据库模式设置为STRICT_TRANS_TABLES模式: mysql> set @@sql_mode=STRICT_TRANS_TABLES;   没有最好与最坏的模式,只有最合适的模式。

1.5K20

SQL索引

一、索引概述 介绍: 索引是帮助MySQL高效获取数据的数据结构(有序)。...FROM table_name; 删除索引 DROP INDEX index_name ON table name; 五、SQL性能分析 (一)SQL执行频率 MySQL客户端连接成功后,通过show...MySQL的慢查询日志默认没有开启,需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息: #开启MySQL慢日志查询开关 slow query log=1 #设置慢日志的时间为2秒,SQL...通过nave profiling参数,能够看到当前MySQL是否支持 profile操作: SELECT @@have profiling; 执行一系列的业务SQL的操作,然后通过如下指令查看指令的执行耗时...query_id的SQL语句CPU的使用情况 show profile cpu for query query_id; (四)explain执行计划 EXPLAIN或者DESC命令获取MySQL如何执行

14820

SQL笔记(2)——MySQL的表操作与索引

,DEFAULT '默认值'表示设置该列的默认值为默认值。...在SQL中,修改表中某一列的数据类型是一个重要的操作,因为数据类型决定了该列可以存储的数据种类和范围。...on update CURRENT_TIMESTAMP:表示该列设置了自动更新时间戳功能。 DEFAULT ‘xxx’:表示该列设置了默认值为xxx。...什么是索引 MySQL索引是一种帮助MySQL快速获取数据的数据结构,就像是书的目录一样可以快速访问特定信息。...主键索引索引列中的值必须是唯一的,不允许有空值。 普通索引MySQL中基本索引类型,没有什么限制,允许在定义索引的列中插入重复值和空值。 唯一索引索引列中的值必须是唯一的,但是允许为空值。

1.6K20

MySQL数据库:SQL优化与索引优化

is null; — mysql低版本不能使用索引 select id from t where num=0; — 可以在num上设置默认值0,确保表中num列没有null...10、利用索引下推减少回表的次数: 索引下推是Mysql5.6版本推出的功能,用于优化查询。...在使用索引下推的情况下,如果存在某些被索引的列的判断条件时,MySQL服务器将这一部分判断条件传递给存储引擎,然后由存储引擎通过判断索引是否符合MySQL服务器传递的条件,只有当索引符合条件时才会将数据检索出来返回给...二、SQL语句优化: 1、减少请求的数据量: (1)只返回必要的列,用具体的字段列表代替 select * 语句 MySQL数据库是按照行的方式存储,而数据存取操作都是以一个页大小进行IO操作的,每个...27、在所有的存储过程和触发器的开始处设置 SET NOCOUNT ON ,在结束时设置 SET NOCOUNT OFF 。 28、尽量避免大事务操作,提高系统并发能力。

1.3K20

SQL优化 MySQL版 – B树索引详讲

为什么要进行SQL优化呢?...很显然,当我们去写sql语句时: 1会发现性能低 2.执行时间太长, 3.或等待时间太长 4.sql语句欠佳,以及我们索引失效 5.服务器参数设置不合理 SQL语句执行过程分析 1.编写过程: 编写过程就是我们平常写...,查这个“王”之前先去翻看目录,发现“W”在300页,因为王首字母是“W”,我们直接去在300页中找,这样找起来就非常快; 索引在数据库中是关键字insex,用官方的定义的意思来说,索引就是帮助MySQL...其实它就是一个树,我们用的比较多的就是B树、Hash树,在MySQL里面,用的就是B树索引; B树索引 首先我画一个图,假装这个是数据表,并且给age列加一个索引: 就把这个索引当成一个目录,也就是age...IO的使用率 2.降低CPU使用率 比如说我sql里面有一个order by desc 根据年龄降序或升序,如果没有索引,你需要把age全部拿出来全部排个序,但是如果有了索引,你就不需要排序了,B树本身就是一个排好序的结构

31810

MySQL优化方案(一)优化SQL脚本与索引

本文记录MySQL优化方案 ,梗概如下: 优化SQL 优化索引 (一)优化SQL 1、通过MySQL自有的优化语句 优化SQL语句,通过脚本命令来了解执行率较低的语句,显示一下状态等。...SHOW命令 SHOW Status可以了解SQL的执行频率。可以显示日志,显示特定的数据库、表、索引以及进程还有权限表中的信息等等。 ?...EXPLAIN 通过EXPALIN命令可以分析低效的SQL执行计划。...MySQL会想Select * 那样进行全表扫描遍历。使用> <给定区间较好。 (二)优化索引 MySQL索引是在存储引擎层面实现的,并不是在服务器层面实现的。...所以每一种的存储引擎的索引都是不是完全相同的。 MySQL目前提供了一下4种索引(概念)。 B-Tree索引:最常见的搜索引擎。大部分的搜索搜索引擎是支持B-Tree。

2.3K70

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券