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

MySQL性能优化(二):优化数据库设计

数据库设计 数据库命名:数据库名的命名一般和项目的名称保持一致,不要随意的起名字。 数据库编码: 尽量采用utf8mb4而不使用utf8。...表的设计 数据库表结构的设计是最基础也是最重要的,因为一旦数据库设计完毕并投入使用,将来再进行修改就相对比较麻烦,特别数据量大时增加字段修改字段类型都比较麻烦,因此在进行数据库设计的时候一定要尽可能的考虑周到...数据库设计要遵守如下原则: 表名 表的命名一般遵守 “业务名称 _ 表名“或者是“项目名_ 表名“的格式,对于业务名称一般都是简写,不全拼,全拼表名会太长,如sys_user(系统模块对应的用户表),...字段名 MySQL 在 Windows 下不区分大小写,但在 Linux 下默认是区分大小写。因此,数据库名、 表名、字段名,最好都统一为小写字母,避免节外生枝。...含有空值的列很难进行查询优化,而且对表索引时不会存储NULL值的,所以如果索引的字段可以为NULL,索引的效率会下降很多。因为它们使得索引、索引的统计信息以及比较运算更加复杂。

2K20

Mysql实例 数据库优化--数据库设计

一.前言 现如今,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显,所以要重视数据库的性能优化。...SQL效率 其它 根据上述问题,将数据库优化分为几个阶段进行调整,力求让数据库发挥好的性能和稳定运行。...二.数据库设计 项目立项后,开发部门根据产品部门需求开发项目。开发工程师在开发项目初期会对表结构设计。对于数据库来说,表结构设计很重要,如果设计不当,会直接影响到用户访问网站速度,用户体验不好!...sql语句优化 1.EXPLAIN分析SELECT查询 很多情况下,使用EXPLAIN关键字可以知道MySQL是如何处理SQL语句的,这可以帮助分析查询语句,从而或许能尽快的找到优化方法以及潜在的性能问题...17.建议开启查询缓存 大多数的MySQL服务器都开启了查询缓存,这是提高性能最有效的方法之一,因为查询缓存由MySQL数据库引擎自动处理,当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中

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

MySQL设计优化

前言 怎么设计优雅的表结构?指导原则是什么? 索引为什么那么快?底层为什么要用B+树? 怎么设计好的索引? 怎么优化索引? 常用系统参数代表什么意思?怎么优化参数? mysql优化手段有哪些?...目录 基本概念 mysql概述 innodb引擎架构 mysql设计 mysql优化 总结 一. 基本概念 1. 关系模型 一对一 一对多 多对多 ? 2....:遵守范式,以减少冗余 数据库查询效率怎么提升:设计好的表结构和索引 数据库查询慢的时候怎么优化:介绍了几种优化手段 2....怎么设计好的索引? 怎么优化索引? 根据查询条件设置合适的组合索引,时常用explain分析并调整索引 常用系统参数代表什么意思?怎么优化参数? 略 mysql优化手段有哪些?...索引优化,参数优化,主从优化,分库分表等等 参考文献 《mysql技术内幕(innodb存储引擎)》 《高性能mysql

1.1K41

性能优化-MySQL数据库优化

2、mysql数据库优化 可以从哪几个方面进行数据库优化?如下图所示: ?...这个时候就要了解sql优化 B、数据库表结构优化 根据数据库的范式,设计表结构,表结构设计的好直接关系到写SQL语句。...C、系统配置优化 大多数运行在Linux机器上,如tcp连接数的限制、打开文件数的限制、安全性的限制,因此我们要对这些配置进行相应的优化。...D、硬件配置优化 选择适合数据库服务的cpu,更快的IO,更高的内存;cpu并不是越多越好,某些数据库版本有最大的限制,IO操作并不是减少阻塞。...注:通过上图可以看出,该金字塔中,优化的成本从下而上逐渐增高,而优化的效果会逐渐降低。

3.8K20

MySQL 性能优化优化设计设计原则解读

作者:秋日芒草 原文:https://my.oschina.net/qrmc/blog/1819509 MySQL性能优化的目的 如何合理的设计数据库?...什么样的数据库设计才能给后期DBA优化提供基石? 数据库设计与程序设计的差异? ? 数据库设计早期优化 1. 关系明确(理清表之间的关系,可以通过冗余的方式提高效率) 2....层级数据库(注册表) 如:Windows操作系统的核心就是一个注册表,由于配置项比较多,采用层级关系的数据存储 2. 关系型数据库 如:MySQL 3. 时序数据库 4....优化设计第三步 数据库优化策略 1、选择小的数据类型 2、单独设计主键,并考虑分布式扩展 3、外键设计 (重要,我们之前开发都是直接使用的弱外键来设置主外键关系,而实际项目中,如果要是删除了主键对应的记录后...,帐户变动或业务处理的中间值 在设计数据库的时候应当落实如下的原则 (一)降低对数据库功能的依赖(如在业务上使用了MySQL特性,且这个特性是只有MySQL存在的,对以后的数据库迁移会带来很大的麻烦)

79831

MySQL-性能优化-优化设计设计原则

MySQL性能优化目的 如何合理的设计数据库? 什么样的数据库设计才能给后期DBA优化提供基石? 数据库设计与程序设计的差异? ? 数据库设计早期优化 1....层级数据库(注册表) 如:Windows操作系统的核心就是一个注册表,由于配置项比较多,采用层级关系的数据存储 2. 关系型数据库 如:MySQL 3. 时序数据库 4....“abc 7个空格 ”,在精准查询(where)就必须带上后面的7个空格 varchar 不存的时候不占空间,存多长数据就占多少空间 优化设计第二步 如何合理的设计出符合三范式数据库表?...优化设计第三步 数据库优化策略 1、选择小的数据类型 2、单独设计主键,并考虑分布式扩展 3、外键设计 (重要,我们之前开发都是直接使用的弱外键来设置主外键关系,而实际项目中,如果要是删除了主键对应的记录后...在设计数据库的时候应当落实如下的原则 (一)降低对数据库功能的依赖(如在业务上使用了MySQL特性,且这个特性是只有MySQL存在的,对以后的数据库迁移会带来很大的麻烦) (二)定义实体关系的原则 牵涉到的实体

70820

mysql之MVCC 配置优化 数据库设计(四)

文章目录 MVCC(多版本并发控制) MVCC 逻辑流程 undo log 快照读与当前读 redo log 配置优化 mysql服务器参数类型 配置文件 全局配置文件配置 常见全局配置文件配置 mysql...内存参数配置 数据库设计 三大范式 MVCC(多版本并发控制) Multiversion concurrency control (版本并发控制):并发访问(读或写)数据库时,对正在事务内处理的数据做多版本的管理...to disk[ 最安全,性能最差的方式] 取值 2 每次事务提交执行Redo buffer --> Redo log OS cache 再每一秒执行 ->flush cache to disk 配置优化...innodb_lock_wait_timeout InnoDB事务在被回滚之前可以等待一个锁定的超时秒数 https://www.cnblogs.com/wyy123/p/6092976.html 常见配置的帖子 数据库设计...所有关系型数据库系统都满足第一范式)数据库表中的字段都是单一属性的, 不可再分; 第二范式( 2NF): 要求实体的属性完全依赖于主键。

1K20

Mysql数据库优化

存储引擎的特点:本身是MySQL数据库服务器的底层组件之一,最大的特点是采用“可插拔”的存储引擎架构。...PERFORMANCE_SCHEMA存储引擎 PERFORMANCE_SCHEMA存储引擎: MySQL .5.7中performance_ schema数据库中所有数据表的存储引擎。...作用:主要用于收集数据库服务器性能参数。 9. FEDERATED存储引擎 FEDERATED存储引擎:默认情况下在MySQL中不可用。 启动:利用“–federated"选项。...INDEX 索引名 #语法2 DROP INDEX 索引名 ON 数据表 [算法选项][锁选项] 例: 3.锁机制 简单的说,锁机制就是为了保证多用户并发操作时,能使被操作的数据资源保持一致性的设计规则...从数据库优化的角度来考虑:尽量减少表级锁定时间,提高多用户的并发能力。. 如何释放“显式”表级锁: UNLOCK TABLES语句。

2.4K20

Mysql数据库优化

仍觉满天星辰不如你', 1);             SET  i = i + 1;         END while;     end 我们先插入10000条,太少了查询时间没差异 3、sql优化...source=dra 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引 。...因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。然而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。...  select num from a where exists(select 1 from b where num=a.num) 14.并不是所有索引对查询都有效,SQL是根据表中数据来进行查询优化的...17.尽量使用数字型字段,若只含数值信息的字段尽量不要设计为字符型,这会降低查询和连接的性能,并会增加存储开销。

1.8K30

MySQL数据库优化

引言: 关于数据库优化,网上有不少资料和方法,但是不少质量参差不齐,有些总结的不够到位,内容冗杂偶尔发现了这篇文章,总结得很经典,文章流量也很大,所以拿到自己的总结文集中,积累优质文章,提升个人能力,希望对大家今后开发中也有帮助...1、选取最适用的字段属性 MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。...因为在MySQL中,ENUM类型被当作数值型数据来处理,而数值型数据被处理起来的速度要比文本类型快得多。这样,我们又可以提高数据库的性能。...如果要在MySQL中使用外键,一定要记住在创建表的时候将表的类型定义为事务安全表InnoDB类型。该类型不是MySQL表的默认类型。...8、优化的查询语句 绝大多数情况下,使用索引可以提高查询的速度,但如果SQL语句使用不恰当的话,索引将无法发挥它应有的作用。 下面是应该注意的几个方面。

1.6K20

原 荐 MySQL-性能优化-优化设计设计

MySQL-性能优化-优化设计设计原则 MySQL性能优化目的 如何合理的设计数据库? 什么样的数据库设计才能给后期DBA优化提供基石? 数据库设计与程序设计的差异?...数据库设计早期优化 1. 关系明确(理清表之间的关系,可以通过冗余的方式提高效率) 2. 节省空间(根据业务经验,设置字段长短) 3....层级数据库(注册表) 如:Windows操作系统的核心就是一个注册表,由于配置项比较多,采用层级关系的数据存储 2. 关系型数据库 如:MySQL 3. 时序数据库 4....优化设计第三步 数据库优化策略 1、选择小的数据类型 2、单独设计主键,并考虑分布式扩展 3、外键设计 (重要,我们之前开发都是直接使用的弱外键来设置主外键关系,而实际项目中,如果要是删除了主键对应的记录后...,帐户变动或业务处理的中间值 在设计数据库的时候应当落实如下的原则 (一)降低对数据库功能的依赖(如在业务上使用了MySQL特性,且这个特性是只有MySQL存在的,对以后的数据库迁移会带来很大的麻烦)

69340

【DB优化MySql数据库优化概述

设计优化 III.1存储引擎的选择 Myisam:数据库并发不大,读多写少,而且都能很好的用到索引,sql语句比较简单的应用,TB数据仓库 Innodb:并发访问大,写操作比较多,有外键、事务等需求的应用...反范式设计 适当的使用冗余的反范式设计,以空间换时间有的时候会很高效。...IV Mysql软件优化 开启mysql复制,实现读写分离、负载均衡,将读的负载分摊到多个从服务器上,提高服务器的处理能力。...使用推荐的GA版本,提升性能 利用分区新功能进行大数据的数据拆分 V Mysql配置优化 注意:全局参数一经设置,随服务器启动预占用资源。...VI Mysql语句级优化 1. 性能查的读语句,在innodb中统计行数,建议另外弄一张统计表,采用myisam,定期做统计.一般的对统计的数据不会要求太精准的情况下适用。 2.

2.3K60

MySQL性能管理及架构设计(二):数据库结构优化、高可用架构设计数据库索引优化

一、数据库结构优化(非常重要) 1.1 数据库结构优化目的 1....总结:要避免异常,需要对数据库结构进行范式化设计。 3. 节约数据存储空间。 4. 提高查询效率。...1.2 数据库结构设计步骤 需求分析:全面了解产品设计的存储需求、数据处理需求、数据安全性与完整性; 逻辑设计(重要):设计数据的逻辑存储结构。数据实体之间的逻辑关系,解决数据冗余和数据维护异常。...数据范式可以帮助我们设计; 物理设计:表结构设计,存储引擎与列的数据类型; 维护优化:****索引优化、存储结构优化。 1.3 数据库范式设计与反范式化 1.4 物理设计 ? ? ?...二、高可用架构设计 ? ? 2.1 读写分离 ? 三、数据库索引优化(非常重要) 3.1 两种主要数据结构:B-tree和Hash 3.1.1 B-tree结构 ? B-tree索引的限制: ?

77510

mysql数据库优化(二)

explain 中 Extra 发生排序 的 标志是 Using Filesort(不是说进行磁盘文件排序,只是一个标志而已) 13.由于MySQL数据库是基于行(Row)存储的数据库,而数据库操作 IO.../mysql-slow.log long_query_time = 0.1              3.通过 mysqld restart 重启数据库     (但是自己重启后仍然没有配置成功)...:  https://blog.csdn.net/cx136295988/article/details/76690722 15.mysql常量含义                  用于配置数据库  ...https://blog.csdn.net/longxibendi/article/details/6704969 16.数据库优化规则。                ...的值等,通过拆分表格,放到新表中,达到减少查询数据量的目的                 4.进行批量操作                 5.优化业务逻辑,根据实际业务数据情况进行优化sql查询方式等

1.1K20

数据库性能优化(MySQL)

11.1 查看数据库状态 可以通过show status、show innodb status 来查看MySQL数据库的状态,使用mysqlreport这个第三方工具可使数据库状态报告更好看(mysqlreport...11.2 正确使用索引 在影响数据库查询性能的众多因素中,索引绝对是一个重量级的因素,如果索引使用不当,则数据库的其它优化可能无济于事。...查询优化器会为一次查询是否使用索引以及决定使用哪个索引,当然,有时查询优化器也会犯错误。...11.8 反范式设计 所谓范式就是对关系数据库中的关系的要求或约束,有不同程序的要求就有不同的范式。...反范式化就是违背关系设计的要求或约束,用于减少读取数据的开销,增加一定的数据冗余,但这样同时也增加了写数据的开销,因为要保持冗余数据的一致性。当然,为了保证数据库写性能可以异步写数据。

3.2K80

MySql数据库优化细节

MySql数据库优化细节 MySQL 数据库性能的优化MySQL 数据库发展的必经之路, MySQL 数据库性能的优化也是 MySQL 数据库前进的见证。...记录一些MySQL优化的一些细节 选取最适用的字段属性(出处) MySQL 可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。...因为在 MySQL 中,ENUM类型被当作数值型数据来处理,而数值型数据被处理起来的速度要比文本类型快得多。这样,我们又可以提高数据库的性能。...之所以更有效率一些,是因为 MySQL 不需要在内存中创建临时表来完成这个逻辑上的需要两个步骤的查询工作。...拆分复杂SQL为多个小SQL,避免大事务 避免使用:触发器、函数、存储过程、视图 避免在数据库中进数学运算 MySQL不擅长数学运算和逻辑判断 避免取出大字段且无用的内容 SELECT只获取必要的字段

1.4K20

MySQL数据库优化。。

不管对于哪种服务,对于其优化,无非是从两个方面着手,第一个是对于硬件方面的优化,第二个是对系统以及服务本身的优化。...注意:测试完成之后,记得要关闭调试功能,以免影响数据库的正常使用。 注意:测试完成之后,记得要关闭调试功能,以免影响数据库的正常使用。...注意:测试完成之后,记得要关闭调试功能,以免影响数据库的正常使用。...四、对数据库表结构进行优化数据库表结构的优化大概可以从以下几个方面着手: 将字段很多的表分解成多个表,尽量避免表字段过多; 增加中间表,合理增加冗余字段; 优化插入记录的速度; 在插入数据之前禁用索引...autocommit=0; 分析表,检查表和优化表 所谓分析表,就是分析关键字的分布,检查表就是检查是否存在错误,优化表就是删除或更新造成的空间浪费。

1.4K10

MySQL数据库:参数优化

所以,要优化数据库,首先第一步需要优化的就是 IO,尽可能将磁盘IO转化为内存IO。...本文先从 MySQL 数据库IO相关缓存参数的角度来介绍可以通过哪些参数进行IO优化: 一、参数说明: 1、query_cache_size / query_cache_type (global): Query...这个参数大小是否足够还是比较容易知道的,因为当过小的时候,MySQL 会记录 Warning 信息到数据库的 error log 中,这时候你就知道该调整这个参数大小了。...4、binlog_cache_size (global): Binlog Cache 用于在打开了binlog二进制日志记录功能的环境,是 MySQL 用来提高binlog的记录效率而设计的一个用于短时间内临时缓存...中为了减少磁盘物理IO而设计的主要参数,对 MySQL 的性能起到了至关重要的作用,下面是几个参数的建议取值: query_cache_type : 如果全部使用innodb存储引擎,建议为0,如果使用

1.4K10
领券