mysql8添加索引_MySQL8.0新特性-新的索引方式

三种新的索引方式

1、隐藏索引

MySQL8.0 支持隐藏索引(invisible index),不可见索引

隐藏索引不会被优化器使用,但需要维护。

应用场景:软删除、灰度发布。

软删除:不确定当前索引是否需要删除的时候,软删除,不会彻底删除,可以恢复索引,不需要重新创建,但需要维护。

灰度发布:测试索引,对当前数据库不会参生太多影响,确认有效后,可以取消隐藏,改变为正常索引。

操作:

create table app_user (

pkid int,

age int

);

-- 正常索引

create index age_idx on app_user(age) ;

-- 隐藏索引 ,主键不可以设置尾隐藏索引

create index id_idx on app_user(pkid) invisible;

-- 有一个参数Visible为NO

show index from app_user;

-- 查询优化器对索引的使用情况

-- 会使用索引

explain select * from app_user where age=18;

-- 不会使用索引

explain select * from app_user where pkid=1;

-- 查询优化器的隐藏索引的开关

select @@optimizer_switch\G

-- 查询优化器使用隐藏索引,在当前会话中

set session optimizer_switch="use_invisible_indexes=on";

-- 打开之后可以使用索引

explain select * from app_user where pkid=1;

-- 设置索引可见

alter table app_user index id_idx visiblle;

-- 设置索引隐藏

alter table app_user index id_idx invisiblle;

2、降序索引

MySQL8.0真正支持降序索引(descending index)。

只有InnoDB存储引擎支持降序索引,只支持BTREE降序索引。

MySQL8.0不再对GROUP BY操作进行隐式排序,也就是说,排序必须要使用ORDER BY。

操作:

create table app_dept

(

pkid int,

num int,

cou int,

index idx1(num asc,cou desc)

);

-- 在5.7中是没有desc的,只有8.0才会有desc

show cteate table app_dept\G

insert into app_dept values(1,1,300),(2,6,500),(5,1,256),(3,4,400);

-- 查询优化器使用索引的情况,会发现使用当前索引,但不用额外的排序(using filesort)操作

explain select * from app_dept order by num,cou desc;

-- 反顺序查询,只会出现反向索引扫描(backward index scan),不会重新排序

explain select * from app_dept order by num desc,cou ;

-- GROUP BY 没有默认排序

select count(*) ,cou from app_dept group by cou;

3、函数索引

MySQL8.0支持在索引中使用函数(表达式)的值。

支持降序索引,支持JSON数据索引。

函数索引基于虚拟列功能实现。

create table t1(

c1 varchar(100),

c2 varchar(100)

);

create index idx1 on t1(c1);

-- 创建函数索引

create index fun_idx2 on t1(UPPER(c1);

show index from t1\G

-- 当使用函数时候,就不会走当前普通索引

explain select * from t1 where upper(c1)='A';

-- 走当前函数索引

explain select * from t1 where upper(c2)='A';

-- 添加一个 计算列,并未该列实现索引,虚拟列实现函数索引,

alter table t1 add column c3 varchar(100) generated always as (upper(c1));

-- 创建JSON数据索引测试,data->>'$.name' as char(30) 意思是取当前name值,类型尾char

create table emp(

data json,

index((CAST(data->>'$.name' as char(30))))

);

show index from emp\G

-- 当前就会使用JSON索引

explain select * from emp where CAST(data->>'$.name' as char(30))='A';

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

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

相关文章

mysql crash定位分析_MySQL实例crash的案例详细分析

【问题描述】我们生产环境有一组集群的多台MySQL服务器(MySQL 5.6.21),不定期的会crash,但error log中只记录了重启信息,未记录crash时的堆栈:mysqld_safe Number of processes running now: 0mysqld_safe mysqld restarted接下来…

matlab 读取照片imread,利用matlab读取图像

怎样用matlab读取20张图片并依次展示出来指定路径下 单个文件夹data中所有图像 P .\data\;% 图像文件夹路径 img_path_list dir(strcat(P,*.jpg));%获取该文件夹中所有jpg格式的图像 N length(img_path_list);%获取图像总数量 for j 1:N%逐一读取图像 image_name img_path…

python元素定位input button_python+selenium 定位到元素,无法点击的解决方法

报错selenium.common.exceptions.WebDriverException: Message: Element is not clickable at point (234.75, 22). Other element would receive the click: 需要点击的按钮页面显示不了,需要下拉滚动条,能看到按钮了才能点1、尝试下拉一段滚动条&#…

seo和php哪个容易学,php好学吗?和其它语言比哪个好学?

PHP入门是很简单的,比起C语言来bai说简单许多du而且门槛也不高,只要搭建好服务器zhi环境便能轻松编程,代dao码写好就直接在浏览器看到运行结果,不用像C语言那样编译运行至于你所说的“晦涩的数学题”,个人认为对于入门…

mysql入门优化_MySQL数据库:MySQL十大优化技巧详解

本文主要向大家介绍了MySQL数据库的MySQL十大优化技巧详解,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。WEB开发者不光要解决程序的效率问题,对数据库的快速访问和相应也是一个大问题。希望本文能对大家掌握MySQL优化技巧有…

java 函数签名,Java签名getAlgorithm()方法

可以使用getAlgorithm()类java.security.Signature中的方法获得签名对象的算法名称。此方法不需要任何参数,它返回签名对象的算法名称。演示此的程序如下所示-示例import java.security.*;import java.util.*;public class Demo {public static void main(String[] …

oel 7.0 安装 mysql 5_在linux上安装PostgreSQL 9.4并启动和关闭数据库

PostgreSQL是以加州大学伯克利分校计算机系开发的 POSTGRES, Version 4.2为基础的对象关系型数据库管理系统(ORDBMS)。POSTGRES开创的许多概念在很久以后才出现在商业数据库中。PostgreSQL是最初伯克利代码的一个开放源码的继承者。它支持大部分SQL标准并且提供了许多其它现代特…

php的控制器,php-模块与控制器

我正在为一个PHP框架(不是,另一个)编写点点滴滴,作为学习的经验,希望将来可用于较小的项目.我已经读了很多书,即现有框架的参考文档.我看到模块一词泛滥成灾,根据我的阅读和以前的经验,模块是一个概念,用于划分相关代码(视图,控制器,模型等).我很好奇,在这种情况下如何看待模块…

mysql5.7 glibcxx_3.4.15_CentOS6.5 缺少 libstdc++.so.6(GLIBCXX_3.4.15)

libstdc-4.8.2-16.el7 下载地址:[rootlocalhost kindit]#[rootlocalhost kindit]# rpm -qa | grep libstdclibstdc-4.4.7-4.el6.i686[rootlocalhost kindit]#[rootlocalhost kindit]#[rootlocalhost kindit]# cd /home/kindit/Packages/packages-centos7[rootlocalh…

php文件夹下所有视频播放,PHP使用glob方法遍历文件夹下所有文件

遍历文件夹下所有文件,一般可以使用opendir 与 readdir 方法来遍历。代码:$path dirname(__FILE__); // __FILE__文件的完整路径和文件名。// echo __FILE__; // F:\wamp\www\php20190214\index.php// echo $path; // F:\wamp\www\php20190214$result …

python模拟浏览器请求的库_基于Python模拟浏览器发送http请求

1.使用 urllib2 实现#! /usr/bin/env python# -*- codingutf-8 -*-import urllib2url"https://www.baidu.com"req_header {"User-Agent":"Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11&…

owncloud8 php,owncloud-8.2.3

安装依赖Red Hat Enterprise Linux and CentOS 6 still ship with PHP 5.3. ownCloud requires PHP 5.4 or better. There areseveral third-party repositories that supply PHP 5.4, but you must use the Software Collections (SCL) repository to bein compliance with yo…

影响mysql导入效率的参数_extended-insert对mysqldump及导入性能的影响

参数说明:-e, --extended-insert,长INSERT,多row在一起批量INSERT,提高导入效率,和没有开启 -e 的备份导入耗时至少相差3、4倍,默认开启;用--extended-insertfalse关闭。强烈建议开启&#xff0…

mysql数据库表的类型介绍,mysql数据库表的类型介绍

前言之前我们讲了下载安装数据库,还有如何卸载(虽然直接重装系统就好)那么现在让我们来讲讲"""1、数据库与表的剩余操作编码配置、引擎介绍2、数据库字段的操作3、数据库的数据类型4、数据库字段的约束条件"""数据库的配置通过配置文…

mysql 分表后排序_MySQL优化分库分表,为什么要分表,分表以后如何进行排序查询,业务如何设计?...

昨天面试新人的时候,遇到了这么一个问题,按照自己的想法大体聊了一些,但大多是感性的,并没有完整的了解why and how.今天查了一些相关的资料,包括《MySQL性能调优与架构设计》、《高性能Mysql》,慢慢的整体…

php7 提示500错误解决,升级php7出现500错误怎么办

升级php7出现500错误怎么办发布时间:2020-08-24 10:40:45来源:亿速云阅读:69作者:小新小编给大家分享一下升级php7出现500错误怎么办,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧&#xff01…

oracle 怎么 制造崩溃,oracle数据库崩溃

通过幸存oracle文件修复oracle9i数据问:我没有备分oralce,也没有导出数据库,现在操作系统崩溃了,但是oracle目录下的文件很完整,请问如何修复我的表?答:建一个相同的数据库(磁盘目录相同,否则要改init文件&…

flume-ng 入 oracle,flume-ng-sql-source

支持oracleflume-ng-sql-sourceThis project is used for flume-ng to communicate with sql databasesCurrent sql database engines supportedAfter the last update the code has been integrated with hibernate, so all databases supported by this technology should wo…

php 500 yii,yii2.0出现500错误怎么办

1、首先开启web/index.php defined(YII_DEBUG) or define(YII_DEBUG, true); 将此改为true;看下报错的问题:Exception (Invalid Configuration) yii\base\InvalidConfigException with message The directory is notwritable by the Web process: /home/…

监控视图 oracle,Oracle“并行执行”之四——监控视图

摘自《VLDB and Partitioning Guide》1、视图介绍V$PX_BUFFER_ADVICE提供所有并行查询的BUFFER的历史使用情况,以及相关的建议规划。对于并行执行过程中的内存不足等问题,可以查询这个视图以便能够重新配置一下SGA。V$PX_SESSION提供关于并行进程会话、服…