首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏技术杂记

    Mysql 优化存储4

    优化脚本 一般此过程会非常漫长,可以写一个脚本来后台运行,或简单的控制一下IO [hunter@opti-slave ~]$ cat opti.bash #! /bin/bash cat /path/to/optimize.sql | while read LINE do mysql -u root -pxxxxx -e "$LINE" ,立刻恢复备份 start slave; 通过对比前后数据文件大小,可以明显看到优化效果 一般少也能缩减5%的空间,平均在10%左右,我自己经历最明显效果的是减少了32%的空间,对于一个大库来说,能节省不少磁盘空间 ,并且对查询性能也有一定优化效果 ---- 命令汇总 pt-table-checksum --nocheck-replication-filters --nocheck-binlog-format -- --sync-to-master --databases=youku_db,jd_db,elearning_db,bat_db --print > /tmp/users.sql time nohup mysql

    41620编辑于 2022-03-21
  • 来自专栏Java 汇总

    4.Mysql 优化

    1.ORDER BY的优化        某些情况下,MySQL使用索引排序,尽量避免使用 filesort         即使ORDER BY与索引不完全匹配,也可以使用索引,只要索引的未使用部分和额外的 如果是这样,优化器可能不使用索引。如果SELECT*只选择索引列,则使用索引并避免排序。 * FROM t1 WHERE key_part1 = constantORDER BY key_part2; ---- 假设 key_part1不是索引或索引的一部分,在条件中作为常量条件存在,则优化器也会使用索引 FROM t1 ORDER BY a;  该查询使用到了别名,别名覆盖了查询列明,order by 不能使用索引 ---- FileSort         如果索引不能用于满足ORDER-BY子句,MySQL 为了获得文件排序操作的内存,从MySQL8.0.12开始,优化器会根据需要递增地分配内存缓冲区,直到达到sort_buffer_size系统变量指定的大小,而不是像MySQL8.0.12之前那样预先分配固定数量的

    1K20发布于 2020-10-29
  • 来自专栏迁移内容

    高性能MySQL(4)——查询性能优化

    例如使用单独的汇总表 重写这个复杂的查询,让MySQL优化器能够以更优化的方式执行这个查询 三、重构查询方式 3.1 一个复杂查询还是多个简单查询 MySQL内部每秒能够扫描内存中上百万行数据 MySQL将结果集返回客户端是一个增量、逐步返回的过程。开始生成第一条结果时,MySQL就开始向客户端逐步返回结果集了。 五、 优化特定类型的查询 5.1、优化COUNT()查询 ​ 1). 这样MySQL才有可能使用索引来优化这个过程。** 5.3 优化子查询: 关于优化子查询我们给出的最重要的优化建议就是尽可能使用关联查询代替,至少当前MySQL版本需要这样。 ** ​ 4). 如果没有通过ORDER BY子句显式地指定排序列,当查询使用GROUP BY 子句的时候,结果集会自动按照分组的列进行排序。 ** 5.5 优化LIMIT分页: ​ 1). 使用索引 ​ 2). 要优化这种查询,要么是在页面中限制分页的数量,要么是优化大偏移量的性能。 ​ 3). 尽肯能的使用索引覆盖 ​ 4).

    1.8K10编辑于 2022-12-01
  • 来自专栏IT知识进阶学习

    干货|MySQL性能优化4个小技巧

    前言   MySQL性能优化是一个老生常谈的问题,无论是在实际工作中还是面试中,都不可避免遇到相应的场景,下面博主就总结一些能够帮助大家解决这个问题的小技巧。 SQL优化之前需要确认哪些SQL需要优化,这时就需要引起SQL性能分析工具,主要优化的是查询语句。 SQL性能优化工具 在进行SQL优化之前首先需要确认哪些SQL需要优化,这时就需要使用到SQL性能分析工具,平常工作业务中,主要优化的是查询语句。 配置完成后重启mysql服务端 linux中mysql的慢日志文件在: /var/lib/mysql/localhost-slow.log window可以在my.ini文件中配置具体的地址,示例如下 作为关联条件 ref:使用非唯一性索引进行访问时,可能出现ref range:使用索引进行范围查询时 index:使用到了索引,但是对整个索引都进行了遍历,性能也比较差 all:全表扫描,性能最差 4

    1.3K10编辑于 2022-09-13
  • 来自专栏小工匠聊架构

    MySQL-索引优化篇(4)_索引的维护

    官方文档 https://dev.mysql.com/doc/ ? 如果英文不好的话,可以参考 searchdoc 翻译的中文版本 http://www.searchdoc.cn/rdbms/mysql/dev.mysql.com/doc/refman/5.7/en/index.com.coder114 -- 删除重复索引 举个例子 ,对id 建立了多个索引 ,重复索引 primary key(id) 【主键索引】, unique key(id) 【唯一索引】, index(id)【普通索引】 主键上MySQL

    50730发布于 2021-08-17
  • 来自专栏Java进阶架构师

    mysql优化专题」你们要的多表查询优化来啦!请查收(4

    上一篇讲的是单表查询的优化,(本文末有链接)。当然,对数据表的多表查询也是必不可少的。本篇内容主要讲解多表联合查询的优化 一、多表查询连接的选择: ? (4)尽量使用数字型字段,若只含数值信息的字段尽量不要设计为字符型,这会降低查询和连接的性能,并会增加存储开销。 (6)不要以为使用MySQL的一些连接操作对查询有多么大的改善,其实核心是索引(别打我,下一篇讲) 【mysql优化专题】相关 「mysql优化专题」这大概是一篇最好的mysql优化入门文章(1) 「mysql优化专题」90%程序员都会忽略的增删改优化(2) 「mysql优化专题」单表查询优化的一些小总结(3) 今天多表查询优化就讲到这里,觉得有收获的同学可以收藏关注。 本号内有多个专题,如【数据结构】、【netty专题】、【dubbo专题】、【mysql优化专题】、【redis专题】、【高并发专题】等,将会陆续添加,设置成关键字.

    2.4K20发布于 2018-08-15
  • 来自专栏ops技术分享

    Mysql配置文件 4c8g优化

    一.说明 以下配置适合4核8G及以下的配置,会让性能稍微提高1/3左右。 seconds to run all queries: 0.551 seconds Maximum number of seconds to run all queries: 1.141 seconds 优化后的 =utf8mb4 default-storage-engine=innoDB basedir=/usr/local/mysql datadir=/usr/local/mysql/data socket= /usr/local/mysql/mysql.sock log-error=/var/log/mysql/mysql.log pid-file=/usr/local/mysql/mysql.pid #扩展设置 = 0 expire_logs_days = 7 max_relay_log_size = 512M binlog-ignore-db = mysql binlog-ignore-db = test

    86020发布于 2021-06-11
  • 来自专栏Java架构学习路线

    4MySQL分页查询优化的方法,你知道几个?

    对于数据库分页查询,也有很多种方法和优化的点。下面简单说一下我知道的一些方法。 准备工作 为了对下面列举的一些优化进行测试,下面针对已有的一张表进行说明。 表名:order_history 描述:某个业务的订单历史表 主要字段:unsigned int id,tinyint(4) int type 字段情况:该表一共37个字段,不包含text等大型数据,最大为 数据量:5709294 MySQL版本:5.7.16 线下找一张百万级的测试表可不容易,如果需要自己测试的话,可以写shell脚本什么的插入数据进行测试。 orders_history where id in (select order_id from trade_2 where goods = 'pen') limit 100; 这种 in 查询的方式要注意:某些 mysql 使用临时表优化 这种方式已经不属于查询优化,这儿附带提一下。

    4.9K40发布于 2019-09-29
  • 来自专栏CSDNToQQCode

    MySQL技能完整学习列表6、查询优化——3、查询缓存——4、SQL优化技巧

    查询缓存 MySQL的查询缓存是一种用于存储SELECT语句结果集的机制。当相同的SELECT语句再次被执行时,MySQL可以直接从查询缓存中获取结果,而不需要再次执行查询。 4. SQL优化技巧 MySQL的SQL优化是一个关键的任务,可以显著提高数据库的性能。下面是一些常用的SQL优化技巧,以及具体的示例: 1. 示例: -- 优化前 SELECT * FROM users WHERE id = 1; -- 优化后 SELECT id, name FROM users WHERE id = 1; 4. 示例: SELECT * FROM users LIMIT 10 OFFSET 30; -- 获取第4页的数据,每页10条记录 6.

    50810编辑于 2023-12-01
  • 来自专栏Howl同学的学习笔记

    Mysql优化

    InnoDB MyISAM 事务处理 支持 不支持 全文搜索 不支持 支持 SELECT ,UPDATE,INSERT,DELETE 大量INSERT或UPDATE | DELETE 表一行一行的删除 大量SELECTDELETE | DELETE表先DROP再重建 AUTO_INCREMENT 自增计数器仅存储在主内存中 锁 表锁,行级锁 表锁 外键 支持 不支持 行数 扫描表来计算 保存行数 存储 把数据和索引存放在表空间里面 表被存放在三个文件 跨平台 跨平台可直接拷贝使用 跨平台很难直接拷贝 压

    1.1K40发布于 2020-03-10
  • 来自专栏Lambda

    mysql优化

    服务器配置文件优化 1. MySQL允许最大的进程连接数, 2. 每个主机的连接请求异常中断的最大次数, 3. 设置表高速缓存的数目, 4. 使用explain+慢sql分析 4. show profile 查询SQL在Mysql服务器里面的执行细节和生命周期情况 5. 运维经理 DBA,进行数据库服务器的参数调优。 查询优化: 1. 3. order by group by 优化 慢查询日志:

    1.3K20编辑于 2022-04-13
  • 来自专栏devops_k8s

    Mysql优化

    为什么优化 为了获得成就感? 为了证实比系统设计者更懂数据库? 为了从优化成果来证实优化者更有价值? no 但通常事实证实的结果往往会和您期待相反! 优化有风险,涉足需谨慎! 优化风险 1 . 对于优化来说解决问题而带来的问题控制在可接受的范围内才是有成果。 4 . 保持现状或出现更差的情况都是失败! 5 . 稳定性和业务可持续性通常比性能更重要! 6 . 优化不可避免涉及到变更,变更就有风险! 7 . 优化使性能变好,维持和变差是等概率事件! 8 . 优化不能只是数据库管理员担当风险,但会所有的人分享优化成果! 9 . xfs ssd IO调度策略 提前规划好以上所有问题,减轻MySQL优化的难度。 这个阶段,需要我们DBA深入业务,或者要和开发人员\业务人员配合实现 优化,最根本的是"优化"人; Mysql参数优化测试(8c32g) 服务器配置 image.png image.png time

    1.9K62发布于 2021-06-21
  • 来自专栏云计算linux

    MySQL优化

    15 MySQL优化 数据库性能优化看起来只牵扯到数据库,但其实范围涉及极广,从计算机和网络硬件到操作系统,网络设计到安全,从各种软件再到数据库本身,性能优化从来都不是单一的,而是一个整体。 在进行MySQL优化之前,必须要了解的就是MySQL的查询过程,很多查询优化工作实际上就是遵循一些原则,让MySQL优化器能够按照预想的合理方式运行而已。 OLTP类型数据一般内存是Cpu核心数量的2倍到4倍,没有最佳实践。 IO : raid、no lvm、ext4或xfs、ssd、IO调度策略。 FROM client UNION SELECT name,birthdate FROM author UNION SELECT name,supplier FROM product 4.

    45810编辑于 2024-12-07
  • 来自专栏allsmallpi博客

    MySQL优化

    (3)使用连接(join)来代替子查询 (4)拆分大的delete或insert语句 二、选择合适的数据类型 (1)使用可存下数据的最小的数据类型,整型 < date,time < char,varchar 使用enum、char而不是varchar (4)尽可能使用not null定义字段 (5)尽量少用text,非用不可最好分表 三、选择合适的索引列 (1)查询频繁的列,在where,group by 看到这个的时候,查询就需要优化了     -Using temporary 使用了临时表。看到这个的时候,也需要优化 (3)PROFILING分析SQL语句 1.开启profile。 包括执行状态、是否锁表等 mysql> SHOW processlist; (4)PROCEDURE ANALYSE()取得建议 通过分析select查询结果对现有的表的每一列给出优化的建议 mysql ; 五、定位慢查询 MySQL慢查询 六、分区 MySQL分区和分表 七、配置优化 MySQL配置优化

    93520发布于 2021-02-25
  • 来自专栏友弟技术工作室

    mysql优化

    上篇文章是关于mysql优化的,那个内容是我大学的时候学习的笔记,最近学习发现一些比较好的内容,在这里分享给大家。 版权源于网上。 工作中使用最多的就是MySQL, 但是mysql优化也就是通过建索引以及缓存数据来优化的。使用explain比较多。对于其他的优化技能没有使用过。 ? 1、硬件层相关优化 请一个DBA团队优化,还没有全部把机械硬盘换成ssd来的快。所以,底层硬件也是很重要的。 中的innodb_max_dirty_pages_pct类似); 3、将net.ipv4.tcp_tw_recycle、net.ipv4.tcp_tw_reuse都设置为1,减少TIME_WAIT,提高 ,可自行斟酌是否调整; 3、MySQL层相关优化 3.1、关于版本选择 官方版本我们称为ORACLE MySQL,这个没什么好说的,相信绝大多数人会选择它。

    2.1K70发布于 2018-04-25
  • 来自专栏开发笔记

    MySQL优化

    SQL优化发生在业务量达到一定规模的时候 目的是优化SQL的执行效率 MySQL 优化 优化范围 硬件资源 操作系统参数,数据库参数配置 SQL语句,索引优化 SQL优化 数据库设计优化【规范,前期设计 任何地方都不要使用 select * from t ,用具体的字段列表代替“*”,不要返回用不到的任何字段 尽量避免使用游标,因为游标的效率较差,如果游标操作的数据超过1万行,那么就应该考虑改写 后记——了解MySQL 索引目的 提高查询效率 【类比字典和借书】 如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sql。 ----------------2019/10/9 参考《MySQL DBA工作笔记》中杨建荣老师举得一个非常形象的例子: “比如某公司里面有一个开发小组,组长管理一些程序员,自己也参与开发工作”——B MySQL默认使用B+Tree索引 索引本身也很大,所以存储在磁盘中,需要加载到内存中执行。 故:索引结构优劣标准:磁盘I/O次数 BTree是为了充分利用磁盘预读功能而创建出来的一种数据结构。

    1.3K40发布于 2020-01-22
  • 来自专栏后端码事

    MYSQL 优化

    深度应用者则着眼于从改进Mysql软件自身层面,或者开发另外的数据库引擎和硬件应用来拓展Mysql的生态系统。 数据库层面优化 影响数据库应用性能的最重要因素其设计的合理性: 表的结构是否合适? ' 条件key_part1 = 1 可以定义如下区间: (1,-inf,-inf) <= (key_part1,key_part2,key_part3) < (1,+inf,+inf) 这个区间包含第4、 key3 = 3; SELECT * FROM innodb_table WHERE (key1 = 1 AND key2 = 2) OR (key3 = 'foo' AND key4 IS NULL 优化 MySQL对col_name IS NULL 的优化和对col_name = constant_value的优化方式一样。 MySQL也可以优化类似col_name = expr OR col_name IS NULL这样的组合。这种形式通常见于子查询。

    3K40发布于 2020-09-11
  • 来自专栏devops_k8s

    Mysql优化

    为什么优化 为了获得成就感? 为了证实比系统设计者更懂数据库? 为了从优化成果来证实优化者更有价值? no 但通常事实证实的结果往往会和您期待相反! 优化有风险,涉足需谨慎! 优化风险 1 . 对于优化来说解决问题而带来的问题控制在可接受的范围内才是有成果。 4 . 保持现状或出现更差的情况都是失败! 5 . 稳定性和业务可持续性通常比性能更重要! 6 . 优化不可避免涉及到变更,变更就有风险! 7 . 优化使性能变好,维持和变差是等概率事件! 8 . 优化不能只是数据库管理员担当风险,但会所有的人分享优化成果! 9 . xfs ssd IO调度策略提前规划好以上所有问题,减轻MySQL优化的难度。 避免业务逻辑错误,避免锁争用.这个阶段,需要我们DBA深入业务,或者要和开发人员\业务人员配合实现优化,最根本的是"优化"人; Mysql参数优化测试(8c32g) 服务器配置 time用于计时 dd

    1.4K30编辑于 2022-05-09
  • 来自专栏编程之禅

    MySQL优化

    MySQL优化 MySQL 优化方案 对于 **MySQL** 的性能优化,大部分情况下都是想减少查询所消耗的时间;而一个查询是由很多个环节组成,那么就需要从每个环节消耗时间进行入手。 配置优化(连接) 当客户端连接到服务端有可能服务端连接数不够导致应用程序获取不到连接而报出 **Mysql: error 1040: Too many connections**** **的错误。 中提供了一个执行计划工具,通过该工具可以模拟优化执行 **SQL** 查询语句的过程得到 **MySQL**  是怎么对一条 **SQL** 语句的过程并且可以对其进行分析。 **2 * 3 * 4 = 6 * 4 = 24**。 通过模拟优化器执行 **SQL** 查询语句的过程得到 **MySQL** 是怎么处理一条 **SQL** 语句的并可以对其进行语句或表的性能瓶颈。

    94920编辑于 2022-05-10
  • 来自专栏全栈程序员必看

    MySql优化

    mysql多表连接查询的模式 左表和右表的共有部分,即内连接 SELECT fileds FROM TableA AS A INNER JOIN TableB AS B ON A.key1 = fields FROM TableA AS A RIGHT JOIN TableB AS B ON A.key1 = B.key2 WHERE A.key1 IS NULL; 左表的全部+右表的全部 mysql 索引的概念 官方定义:索引是帮助mysql高效获取数据的数据结构。划重点:数据结构。 索引按字段分类 单值索引:索引只包含1个列,一个表可以建多个单值索引 复合索引:索引包含多个列 唯一索引:索引列的值必须是唯一的,但允许有空值 4. 查看索引 SHOW INDEX FROM tableName\G 其中,tableName是表名,\G是为了显示格式优化。 7.

    90630编辑于 2022-08-05
领券