MySQL 13:MySQL优化

24 篇文章 2 订阅
订阅专栏
文章介绍了MySQL性能优化的各种方法,包括通过showstatus和慢查询日志定位低效SQL,使用EXPLAIN分析执行计划,以及如何创建和利用索引来提升查询速度。还提到了通过showprofiles分析SQL执行过程和使用trace进行优化器执行计划的深入分析。此外,文章强调了避免索引失效的规则和大批量数据插入的优化策略。
摘要由CSDN通过智能技术生成

在应用开发过程中,由于初期数据量较小,开发人员在编写SQL语句时更注重功能的实现。但是,当应用系统正式上线后,随着生产数据量的激增,逐渐暴露出很多SQL语句。 如果出现性能问题,对生产的影响也越来越大。这时,这些有问题的SQL语句就成为了整个系统性能的瓶颈,所以我们必须对其进行优化。

优化MySQL的方法有很多,大致可以从以下几点来优化MySQL:

从设计上优化
从查询上优化
从索引上优化
从存储上优化

MySQL客户端连接成功后,可以通过show [session|global] status命令查看服务器状态信息。 通过查看状态信息,可以查看当前数据库的主要操作类型。

--下面的命令显示了当前 session 中所有统计参数的值
show session status like 'Com_______';  -- 查看当前会话统计结果
show global  status  like 'Com_______';  -- 查看自数据库上次启动至今统计结果
 
show status like 'Innodb_rows_%’;       -- 查看针对Innodb引擎的统计结果

定位低效率执行SQL 

可以通过以下两种方式定位执行效率较低的 SQL 语句。 

慢查询日志 : 通过慢查询日志定位那些执行效率较低的 SQL 语句。

show processlist:该命令查看当前MySQL在进行的线程,包括线程的状态、是否锁表等,可以实时地查看 SQL 的执行情况,同时对一些锁表操作进行优化。

-- 查看慢日志配置信息 
show variables like '%slow_query_log%'; 

-- 开启慢日志查询 
set global slow_query_log=1; 

-- 查看慢日志记录SQL的最低阈值时间 
show variables like 'long_query_time%'; 

-- 修改慢日志记录SQL的最低阈值时间 
set global long_query_time=4;

 定位低效率执行SQL-show processlist

show processlist; 

1)id列:用户登录mysql时,可以使用函数connection_id()查看系统分配的“connection_id”

2) user列:显示当前用户。 如果你不是root,这个命令只会显示用户权限范围内的sql语句

3) host列:显示语句是从哪个IP端口发出的,可以用来跟踪出问题语句的用户

4)db列:显示进程当前连接到哪个数据库

5)command列:显示当前连接执行的命令,一般取值有sleep、query、connect等。

6)time列:以秒为单位显示该状态的持续时间

7)state列:显示使用当前连接的SQL语句的状态,是一个很重要的栏。 state 描述语句执行中的某种状态。 一条sql语句,以查询为例,可能需要经过复制到tmp表、排序结果、发送数据等状态才能完成

8)info列:显示这条sql语句,是判断问题语句的重要依据

explain分析执行计划

通过以上步骤查询出低效的SQL语句后,可以使用EXPLAIN命令获取MySQL是如何执行SELECT语句的信息,包括在SELECT语句执行过程中表是如何连接的以及连接顺序。

-- 准备测试数据 
create database mydb13_optimize; 
use mydb13_optimize; 
--执行sql脚本sql_optimize.sql添加数据 
explain select * from user where uid = 1;

explain select * from user where uname = '张飞';

id 字段是 select查询的序列号,是一组数字,表示的是查询中执行select子句或者是操作表的顺序。id 情况有三种:

1、id 相同表示加载表的顺序是从上到下。

explain select * from user u, user_role ur, role r where u.uid = ur.uid and ur.rid = r.rid ;

2、 id 不同id值越大,优先级越高,越先被执行。 

explain select * from role where rid = (select rid from user_role where uid = (select uid from user where uname = '张飞'))

3、 id 有相同,也有不同,同时存在。id相同的可以认为是一组,从上往下顺序执行;在所有的组中,id的值越大,优先级越高,越先执行。

explain select * from role r , (select * from user_role ur where ur.uid = (select uid from user where uname = '张飞')) t where r.rid = t.rid ; 

Explain分析执行计划-Explain 之 select_type

表示 SELECT 的类型,常见的取值,如下表所示:

 Explain分析执行计划-Explain 之 type

type 显示的是访问类型,是较为重要的一个指标,可取值为: 

结果值从最好到最坏以此是:system > const > eq_ref > ref > range > index > ALL

Explain分析执行计划-其他指标字段

Explain 之 table 

显示这一步所访问数据库中表名称有时不是真实的表名字,可能是简称。

explain 之 rows

扫描行的数量。

Explain 之 key

possible_keys :显示可能应用于此表的索引,一个或多个。

key : 实际使用的索引,如果为NULL,则不使用该索引。

key_len :指示索引中使用的字节数。 该值是索引字段的最大可能长度,而不是实际使用的长度。 长度越短越好,而且不会损失准确性。

Explain之 extra 

其他的额外的执行计划信息,在该列展示 。

show profile分析SQL

Mysql从5.0.37版本开始增加了对show profiles和show profile语句的支持。 show profiles可以帮助我们了解在做SQL优化的时候,时间都花在了哪些地方。

通过 have_profiling 参数,能够看到当前MySQL是否支持profile:

select @@have_profiling; 
set profiling=1; -- 开启profiling 开关; 

通过profile,我们能够更清楚地了解SQL执行的过程。首先,我们可以执行一系列的操作。

show databases;
 
use mydb13_optimize;
 
show tables;
 
select * from user where id < 2;
 
select count(*) from user;

执行完上述命令之后,再执行show profiles 指令, 来查看SQL语句执行的耗时:

show profiles;

通过show  profile for  query  query_id 语句可以查看到该SQL执行过程中每个线程的状态和消耗的时间:

show profile for query 8;

MySQL在获取最耗时的线程状态后,支持进一步选择all、cpu、block io、context switch、page faults等详细类型,查看MySQL正在使用哪些资源耗时过多。 例如选择查看CPU时间:

show profile cpu for query 133;  

 

trace分析优化器执行计划

MySQL5.6提供了对SQL的跟踪trace, 通过trace文件能够进一步了解为什么优化器选择A计划, 而不是选择B计划。

打开trace,设置格式为JSON,并设置trace可以使用的最大内存大小,避免在解析过程中因为默认内存太小而显示不完整。

SET optimizer_trace="enabled=on",end_markers_in_json=on; 
set optimizer_trace_max_mem_size=1000000;

执行SQL语句:

select * from user where uid < 2;

最后, 检查information_schema.optimizer_trace就可以知道MySQL是如何执行SQL的 :

select * from information_schema.optimizer_trace\G;

使用索引优化

索引是数据库优化最常用也是最重要的手段之一, 通过索引通常可以帮助用户解决大多数的MySQL的性能优化问题。

数据准备:

create table `tb_seller` (
    `sellerid` varchar (100),
    `name` varchar (100),
    `nickname` varchar (50),
    `password` varchar (60),
    `status` varchar (1),
    `address` varchar (100),
    `createtime` datetime,
    primary key(`sellerid`)
); 

insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('alibaba','阿里巴巴','阿里小店','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('baidu','百度科技有限公司','百度小店','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('huawei','华为科技有限公司','华为小店','e10adc3949ba59abbe56e057f20f883e','0','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('itcast','传智播客教育科技有限公司','传智播客','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('itheima','黑马程序员','黑马程序员','e10adc3949ba59abbe56e057f20f883e','0','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('luoji','罗技科技有限公司','罗技小店','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');

insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('oppo','OPPO科技有限公司','OPPO官方旗舰店','e10adc3949ba59abbe56e057f20f883e','0','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('ourpalm','掌趣科技股份有限公司','掌趣小店','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('qiandu','千度科技','千度小店','e10adc3949ba59abbe56e057f20f883e','2','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('sina','新浪科技有限公司','新浪官方旗舰店','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('xiaomi','小米科技','小米官方旗舰店','e10adc3949ba59abbe56e057f20f883e','1','西安市','2088-01-01 12:00:00');
insert into `tb_seller` (`sellerid`, `name`, `nickname`, `password`, `status`, `address`, `createtime`) values('yijia','宜家家居','宜家家居旗舰店','e10adc3949ba59abbe56e057f20f883e','1','北京市','2088-01-01 12:00:00');

-- 创建组合索引 
create index idx_seller_name_sta_addr on tb_seller(name,status,address);

避免索引失效应用-全值匹配

该情况下,索引生效,执行效率高。

explain select * from tb_seller where name='小米科技' and status='1' and address='北京市';

避免索引失效应用-最左前缀法则

该情况下,索引生效,执行效率高。

-- 最左前缀法则
-- 如果索引了多列,要遵守最左前缀法则。指的是查询从索引的最左前列开始,并且不跳过索引中的列。
explain select * from tb_seller where name='小米科技'; -- 403
 
explain select * from tb_seller where name='小米科技' and status='1'; -- 410
explain select * from tb_seller where  status='1' and name='小米科技'; -- 410
-- 违法最左前缀法则 , 索引失效:
explain select * from tb_seller where status='1'; -- nulll
 
-- 如果符合最左法则,但是出现跳跃某一列,只有最左列索引生效:
explain select * from tb_seller where name='小米科技'  and address='北京市'; -- 403

-- 范围查询右边的列,不能使用索引 。 
explain select * from tb_seller where name='小米科技' and status >'1' and address='北京市’; 

-- 不要在索引列上进行运算操作, 索引将失效。 
explain select * from tb_seller where substring(name,3,2)='科技’ 

-- 字符串不加单引号,造成索引失效。 
explain select * from tb_seller where name='小米科技' and status = 1 ;

-- 1、范围查询右边的列,不能使用索引 。
-- 根据前面的两个字段name , status 查询是走索引的, 但是最后一个条件address 没有用到索引。
explain select * from tb_seller where name='小米科技' and status >'1' and address='北京市';
 
-- 2、不要在索引列上进行运算操作, 索引将失效。
explain select * from tb_seller where substring(name,3,2)='科技'
 
-- 3、字符串不加单引号,造成索引失效。 
explain select * from tb_seller where name='小米科技' and status = 1 ;
 
-- 4、尽量使用覆盖索引,避免select *
-- 需要从原表及磁盘上读取数据
explain select * from tb_seller where name='小米科技'  and address='北京市';  -- 效率低
 
-- 从索引树中就可以查询到所有数据
explain select name from tb_seller where name='小米科技'  and address='北京市';  -- 效率高
explain select name,status,address from tb_seller where name='小米科技'  and address='北京市';  -- 效率高
-- 如果查询列,超出索引列,也会降低性能。
explain select name,status,address,password from tb_seller where name='小米科技'  and address='北京市';  -- 效率低

-- 尽量使用覆盖索引,避免select *
-- 需要从原表及磁盘上读取数据
explain select * from tb_seller where name='小米科技'  and address='北京市';  -- 效率低
 
-- 从索引树中就可以查询到所有数据
explain select name from tb_seller where name='小米科技'  and address='北京市';  -- 效率高
explain select name,status,address from tb_seller where name='小米科技'  and address='北京市';  -- 效率高
-- 如果查询列,超出索引列,也会降低性能。
explain select name,status,address,password from tb_seller where name='小米科技'  and address='北京市';  -- 效率低

-- 用or分割开的条件, 那么涉及的索引都不会被用到。
explain select * from tb_seller where name='黑马程序员' or createtime = '2088-01-01 12:00:00'; 
explain select * from tb_seller where name='黑马程序员' or address = '西安市';  
explain select * from tb_seller where name='黑马程序员' or status = '1';   
 
-- 以%开头的Like模糊查询,索引失效。
explain select * from tb_seller where name like '科技%'; -- 用索引
explain select * from tb_seller where name like '%科技'; -- 不用索引
explain select * from tb_seller where name like '%科技%';-- 不用索引
-- 弥补不足,不用*,使用索引列
explain select name from tb_seller where name like '%科技%';

--  1、如果MySQL评估使用索引比全表更慢,则不使用索引。
-- 这种情况是由数据本身的特点来决定的
create index index_address on tb_seller(address);
 
explain select * from tb_seller where address = '北京市'; -- 没有使用索引
explain select * from tb_seller where address = '西安市'; -- 没有使用索引
 
--  2、is  NULL , is NOT NULL  有时有效,有时索引失效。
create index index_address on tb_seller(nickname);
explain select * from tb_seller where nickname is NULL;  -- 索引有效
explain select * from tb_seller where nickname is not NULL; -- 无效

大批量插入数据

create table `tb_user` (
  `id` int(11) not null auto_increment,
  `username` varchar(45) not null,
  `password` varchar(96) not null,
  `name` varchar(45) not null,
  `birthday` datetime default null,
  `sex` char(1) default null,
  `email` varchar(45) default null,
  `phone` varchar(45) default null,
  `qq` varchar(32) default null,
  `status` varchar(32) not null comment '用户状态',
  `create_time` datetime not null,
  `update_time` datetime default null,
  primary key (`id`),
  unique key `unique_user_username` (`username`)
);

当使用load 命令导入数据的时候,适当的设置可以提高导入的效率。对于 InnoDB 类型的表,有以下几种方式可以提高导入的效率:

1) 主键顺序插入

因为InnoDB表是按照主键顺序存储的,所以将导入的数据按照主键的顺序排列,可以有效提高导入数据的效率。 如果InnoDB表没有主键,系统默认会自动创建一个内部列作为主键,所以如果可以为表创建主键,可以借此提高导入数据的效率。

 

 

-- 1、首先,检查一个全局系统变量 'local_infile' 的状态, 如果得到如下显示 Value=OFF,则说明这是不可用的
show global variables like 'local_infile';
 
-- 2、修改local_infile值为on,开启local_infile
set global local_infile=1;
 
-- 3、加载数据 
/*
脚本文件介绍 :
    sql1.log  ----> 主键有序
    sql2.log  ----> 主键无序
*/
load data local infile 'D:\\sql_data\\sql1.log' into table tb_user fields terminated by ',' lines terminated by '\n';

2 、关闭唯一性校验

在导入数据前执行 SET UNIQUE_CHECKS=0,关闭唯一性校验,在导入结束后执行SET UNIQUE_CHECKS=1,恢复唯一性校验,可以提高导入的效率。

-- 关闭唯一性校验
SET UNIQUE_CHECKS=0;
 
truncate table tb_user;
load data local infile 'D:\\sql_data\\sql1.log' into table tb_user fields terminated by ',' lines terminated by '\n';
 
SET UNIQUE_CHECKS=1;

优化insert语句

当进行数据的insert操作的时候,可以考虑采用以下几种优化方案:

-- 如果需要同时对一张表插入很多行数据时,应该尽量使用多个值表的insert语句,这种方式将大大的缩减客户端与数据库之间的连接、关闭等消耗。使得效率比分开执行的单个insert语句快。

-- 原始方式为:
insert into tb_test values(1,'Tom');
insert into tb_test values(2,'Cat');
insert into tb_test values(3,'Jerry');
 
 
-- 优化后的方案为 : 
 
insert into tb_test values(1,'Tom'),(2,'Cat'),(3,'Jerry');

-- 在事务中进行数据插入。
begin;
insert into tb_test values(1,'Tom');
insert into tb_test values(2,'Cat');
insert into tb_test values(3,'Jerry');
commit;

-- 数据有序插入
insert into tb_test values(4,'Tim');
insert into tb_test values(1,'Tom');
insert into tb_test values(3,'Jerry');
insert into tb_test values(5,'Rose');
insert into tb_test values(2,'Cat');
 
 
-- 优化后
insert into tb_test values(1,'Tom');
insert into tb_test values(2,'Cat');
insert into tb_test values(3,'Jerry');
insert into tb_test values(4,'Tim');
insert into tb_test values(5,'Rose');

优化order by语句

CREATE TABLE `emp` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) NOT NULL,
  `age` int(3) NOT NULL,
  `salary` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
);
 
insert into `emp` (`id`, `name`, `age`, `salary`) values('1','Tom','25','2300');
insert into `emp` (`id`, `name`, `age`, `salary`) values('2','Jerry','30','3500');
insert into `emp` (`id`, `name`, `age`, `salary`) values('3','Luci','25','2800');
insert into `emp` (`id`, `name`, `age`, `salary`) values('4','Jay','36','3500');
insert into `emp` (`id`, `name`, `age`, `salary`) values('5','Tom2','21','2200');
insert into `emp` (`id`, `name`, `age`, `salary`) values('6','Jerry2','31','3300');
insert into `emp` (`id`, `name`, `age`, `salary`) values('7','Luci2','26','2700');
insert into `emp` (`id`, `name`, `age`, `salary`) values('8','Jay2','33','3500');
insert into `emp` (`id`, `name`, `age`, `salary`) values('9','Tom3','23','2400');
insert into `emp` (`id`, `name`, `age`, `salary`) values('10','Jerry3','32','3100');
insert into `emp` (`id`, `name`, `age`, `salary`) values('11','Luci3','26','2900');
insert into `emp` (`id`, `name`, `age`, `salary`) values('12','Jay3','37','4500');
 
create index idx_emp_age_salary on emp(age,salary);

2、两种排序方式

第一种是通过对返回的数据进行排序,也就是通常所说的filesort排序,所有不直接通过索引返回排序结果的排序,都称为filesort排序。

二是通过有序索引顺序扫描直接返回有序数据,称为using index,不需要额外排序,运行效率高。

3、Filesort 的优化

通过创建合适的索引,可以减少Filesort的出现,但在某些情况下,条件限制不能使Filesort消失,所以需要加快Filesort的排序操作。 对于Filesort,MySQL有两种排序算法:

1)二次扫描算法:在MySQL4.1之前,使用这种方法进行排序。 首先根据条件取出排序字段和行指针信息,然后在排序区的排序缓冲区中进行排序。 如果排序缓冲区不够,则将排序结果存入临时表。 排序完成后,根据行指针将记录读回表中,可能会引起大量的随机I/O操作。

2)一次扫描算法:一次性取出所有满足条件的字段,然后在排序缓冲区中排序后直接输出结果集。 排序的内存开销较大,但排序效率高于二次扫描算法。

优化group by

因为GROUP BY其实也进行了排序操作,而与ORDER BY相比,GROUP BY主要只是在排序后增加了分组操作。 当然如果在分组的时候使用了一些其他的聚合函数,那么也需要进行一些聚合函数的计算。 因此,在GROUP BY的实现过程中,也可以像ORDER BY一样使用索引。

如果查询中包含group by,但用户又想避免排序后的结果被消费,可以执行order by null来关闭排序。 如下 :

drop index idx_emp_age_salary on emp; 

explain select age,count(*) from emp group by age;

explain select age,count(*) from emp group by age order by null;

create index idx_emp_age_salary on emp(age,salary);

优化子查询

使用子查询可以一次完成很多逻辑上需要多步才能完成的SQL操作,也可以避免事务或表锁,而且编写简单。 然而,在某些情况下,子查询可以被更高效的连接(JOIN)所取代。

explain select * from user where uid in (select uid from user_role ); 

explain select * from user u , user_role ur where u.uid = ur.uid;

 

system>const>eq_ref>ref>range>index>ALL

连接(Join)查询之所以更有效率一些 ,是因为MySQL不需要在内存中创建临时表来完成这个逻辑上需要两个步骤的查询工作。

优化limit查询

一般分页查询时,通过创建覆盖索引能够比较好地提高性能。一个常见又非常头疼的问题就是 limit 900000,10  ,此时需要MySQL排序前900010 记录,仅仅返回900000 - 900010 的记录,其他记录丢弃,查询排序的代价非常大 。

1、优化思路一

在索引上完成排序分页操作,最后根据主键关联回原表查询所需要的其他列内容。

2、优化思路二

该方案适用于主键自增的表,可以把Limit 查询转换成某个位置的查询 。

10步优化MySQL 8.0:InnoDB引擎性能提升秘籍
java专栏
07-02 1204
想象一下,InnoDB就像是一个精密的瑞士手表,每个部件都设计得恰到好处。它不仅支持事务处理,还提供了行级锁定和外键约束等高级功能。但在这个完美的外表下,隐藏着许多可以优化的小秘密。假设我们有一个电子商务平台的数据库,用户反映查询商品时响应慢。我们将通过一个实战案例,展示如何定位并解决这个问题。
mysql13
Markland_l的博客
07-24 263
buffer pool、redo日志
MySQL (Errcode: 13)
weixin_33736649的博客
11-24 1223
2019独角兽企业重金招聘Python工程师标准>>> ...
MySQL(13):MySQL日志
elegant coder
01-05 162
日志简介 MySQL日志主要分为4类: 错误日志:记录MySQL服务的启动、运行或停止MySQL服务时出现的问题。 查询日志:记录建立的客户端连接和执行的语句。 二进制日志:记录所有更改数据的语句,可用于数据复制。 慢查询日志:记录所有执行时间超过long_query_time的所有查询或不使用索引的查询。 二进制日志 启动和设置二进制日志 my.ini中[mysql]组下面有几个设...
学习MySQL13《Mycat》
weixin_47252600的博客
01-09 271
使用mycat实现mysql分库分表
mysql13版本_Mysql13—— 视图
weixin_39677870的博客
01-20 106
含义:虚拟表,和普通表一样使用mysql5.1版本出现的新特性,是通过表动态生成的数据案例:查询姓张的学生名和专业名SELECT stuname,majornameFROM stuinfo sINNER JOIN major m ON s.`majorid`=m.`id`WHERE s.`stuname` LIKE '张%‘;CREATE VIEW v1ASSELECT stuinfo sINNE...
MySQL索引:优化查询的利器.md
08-15
MySQL索引:优化查询的利器
MySQL技术大全:开发、优化与运维实战
04-14
MySQL技术大全:开发、优化与运维实战 1.MySQL技术大全教学PPT 3. 随书插图Viso文件 1.MySQL技术大全教学PPT 第7章 第9章 第6章 第8章 第3章 第30章 第32章 第33章 第2章 第27章 第29章 第31 章 第23章 第25章 第26...
MySQL性能优化:在Linux上使用Gradle构建高效数据分析
最新发布
08-27
MySQL是一个流行的开源关系型数据库管理系统(RDBMS),广泛用于Web应用程序的后端数据存储。它基于结构化查询语言(SQL)来管理数据,并且是LAMP(Linux, Apache, MySQL, PHP/Python/Perl)技术栈的一部分,这个...
千金良方:MySQL性能优化金字塔法则.docx
09-13
MySQL性能优化金字塔法则 MySQL性能优化是指通过调整MySQL数据库的配置、优化数据库结构和查询语句等方式,提高MySQL数据库的性能和响应速度,以满足应用程序的需求。MySQL作为最流行的开源数据库之一,被广泛应用...
MySQL13-约束
qq_43117059的博客
04-28 844
一. 约束(constraint)概述 1.1. 为什么需要约束 数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。它是防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而提出的。 为了保证数据的完整性,SQL规范以约束的方式对表数据进行额外的条件限制。从以下四个方面考虑: 实体完整性(Entity Integrity) :例如,同一个表中,不能存在两条完全相同无法区分的记录。 域完整性(Domain Int
mysql参数优化
weixin_39735909的博客
10-17 4027
mysql参数设置
mysql性能优化-常用 优化查询以及命令
oradbm的博客
09-23 318
show status -- 显示全部mysql操作信息-- 获得mysql的插入次数;-- 获得mysql的删除次数;-- 获得mysql的查询次数;-- 获得mysql服务器运行时间-- 获得mysql连接次show [session|global] status like .... 如果你不写 [session|global] 默认是session 会话,只取出当前窗口的执行,如果你想看所有(从mysql 启动到现在,则应该 global)
MySQL多种优化手段
weixin_39218464的博客
01-02 494
开启Mysql的查询缓存,当执行完全相同的SQL语句的时候,服务器就会直接从缓存中读取结果,当数据被修改,之前的缓存会失效,修改比较频繁的表不适合做查询缓存。
MYSQL error 3100:error on observer while running replication hook ‘berfore_commit‘
热门推荐
weixin_44359392的博客
12-11 1万+
该错误出现原因: 事务大小超过数据库默认大小。 show global variables like ‘%group_replication_transaction_size_limit%’; 一般大小为141M(150000000) set global group_replication_transaction_size_limit=1500000000;
MySQL:Error on observer while running replication hoot ‘before_commit‘
似水流年,是谁苍白了等待
04-23 1560
Error on observer while running replication hoot 'before_commit' 解决方案
mysql将数据导入mgr_MGR 导入失败
weixin_33121345的博客
02-02 1861
MySQL version:8.0.18-commercial MySQL Enterprise Server - CommercialHA: MGR问题:导入sql文件,大小371MB导入数据过程中[Err] 3100 - Error on observer while running replication hook 'before_commit'.报错日志:2020-06-27T10:24:...
session存储优化之基于mysql的存取
草上飞
09-27 1796
使用MySQL保存session会话较files有很多优点: 1) 有利于分布式系统,files只能保存在一台机器上 2) 有利于大访问量的系统,使用files时每个session保存在一个文件中,目录会超级大,查找session文件会比较困难,当然,也可以自己写一个有hash目录的替代。 使用用数据库保存session。具体方法如下: 1.更改php.ini文件。 由于php默认保存s
2015辛星MySQL教程:优化与建模
这是一份全面覆盖MySQL优化和建模的教程,适合那些希望提升数据库管理能力,尤其是对数据库设计和性能优化感兴趣的读者。通过学习,读者不仅可以掌握理论知识,还能获得实践经验,从而在实际工作中更好地应用MySQL
写文章

热门文章

  • Python 机器学习4:sklearn 分类算法 7884
  • Python 机器学习6:sklearn 线性回归 4143
  • Python OpenCV12:OpenCV 人脸检测 3681
  • 钉钉小程序 企业内部应用开发 3632
  • Python PyTorch6:卷积神经网络 3322

分类专栏

  • Python 81篇
  • Java 24篇
  • SQL 24篇
  • Linux 6篇
  • 研究 15篇
  • HTML_CSS_JavaScript 4篇
  • C++ 2篇

最新评论

  • 基于RMI技术的数据库操作中间件设计 综合实践报告

    苍老的小孩969: 博主,有偿求源码

  • Python入学测试题 江苏某线下培训机构出题

    CSDN-Ada助手: 不知道 Python入门 技能树是否可以帮到你:https://edu.csdn.net/skill/python?utm_source=AI_act_python

  • Python入学测试题 江苏某线下培训机构出题

    CSDN-Ada助手: 不知道 Python入门 技能树是否可以帮到你:https://edu.csdn.net/skill/python?utm_source=AI_act_python

  • 基于RMI技术的数据库操作中间件设计 综合实践报告

    三子666: 博主,有偿求源码

  • 基于RMI技术的数据库操作中间件设计 综合实践报告

    sanking.1: 博主请问您是否可以提供一下源代码以参考学习

大家在看

  • python新手的五个练习题
  • Redis——redispluspls库list及set类型相关接口使用
  • 5.编写ROS程序 456
  • vue3常用的组件间通信 1472
  • 解决Springboot中注入RedisTemplate的Bean对象注入失败的问题

最新文章

  • 黑马一站制造数仓实战2
  • 黑马一站制造数仓实战3
  • 黑马一站制造数仓实战4
2024年6篇
2023年70篇
2021年83篇

目录

目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43元 前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hinomoto Oniko

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或 充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

天下网标王网站优化百度百科黄山做网站优化福建网站快速优化优化网站100种方法网站建设智能优化乌兰察布网站整站优化天津 网站优化邯郸家装行业网站优化推广深圳外贸网站关键词优化工具苏州网站优化最专业罗湖网站优化比较好衡阳企业网站优化方案黄山网站流量优化天津 网站优化安丘网站如何做优化黄山网站优化公司哪家好网站搜索优化seo优化网站外链建设网站优化报价淄博很好的网站优化用户体验建筑网站优化哪家便宜宁夏网站怎么优化惠州品牌网站优化费用徐州网站排名优化公司长沙企业网站优化青浦区360网站优化价格费用网站建设推广方案优化服务重庆淮安网站关键词优化公司推荐昆明市效果好的网站seo优化汕头百度seo网站优化香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声卫健委通报少年有偿捐血浆16次猝死汪小菲曝离婚始末何赛飞追着代拍打雅江山火三名扑火人员牺牲系谣言男子被猫抓伤后确诊“猫抓病”周杰伦一审败诉网易中国拥有亿元资产的家庭达13.3万户315晚会后胖东来又人满为患了高校汽车撞人致3死16伤 司机系学生张家界的山上“长”满了韩国人?张立群任西安交通大学校长手机成瘾是影响睡眠质量重要因素网友洛杉矶偶遇贾玲“重生之我在北大当嫡校长”单亲妈妈陷入热恋 14岁儿子报警倪萍分享减重40斤方法杨倩无缘巴黎奥运考生莫言也上北大硕士复试名单了许家印被限制高消费奥巴马现身唐宁街 黑色着装引猜测专访95后高颜值猪保姆男孩8年未见母亲被告知被遗忘七年后宇文玥被薅头发捞上岸郑州一火锅店爆改成麻辣烫店西双版纳热带植物园回应蜉蝣大爆发沉迷短剧的人就像掉进了杀猪盘当地回应沈阳致3死车祸车主疑毒驾开除党籍5年后 原水城县长再被查凯特王妃现身!外出购物视频曝光初中生遭15人围殴自卫刺伤3人判无罪事业单位女子向同事水杯投不明物质男子被流浪猫绊倒 投喂者赔24万外国人感慨凌晨的中国很安全路边卖淀粉肠阿姨主动出示声明书胖东来员工每周单休无小长假王树国卸任西安交大校长 师生送别小米汽车超级工厂正式揭幕黑马情侣提车了妈妈回应孩子在校撞护栏坠楼校方回应护栏损坏小学生课间坠楼房客欠租失踪 房东直发愁专家建议不必谈骨泥色变老人退休金被冒领16年 金额超20万西藏招商引资投资者子女可当地高考特朗普无法缴纳4.54亿美元罚金浙江一高校内汽车冲撞行人 多人受伤

天下网标王 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化