iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql优化方法详细介绍
  • 450
分享到

Mysql优化方法详细介绍

Mysql优化Mysql优化方法 2023-02-03 09:02:32 450人浏览 薄情痞子
摘要

目录1、字段属性2、字段NOT NULL3、JOIN代替子查询4、UNION代替手动创建临时表5、事务6、索引下面聊聊Mysql常见的优化方法。 1、字段属性 mysql是一

下面聊聊Mysql常见的优化方法。

1、字段属性

mysql是一种关系型数据库,可以很好地支撑大数据量的存储,但一般来说,数据库中的表越小,执行的查询也就越快,因此在建表时,选择最合适的字段属性,使字段的长度尽可能的小。

如,在定义名称字段时,若将其设置为char(255),显然给数据库增加了不必要的空间。

2、字段NOT NULL

尽量把字段设置为NOT NULL,这样在执行查询的时候,数据库不用去比较NULL值了。

3、JOIN代替子查询

sql查询语句中,尽量使用连接join代替子查询,提高查询效率。

如,查询客户基本信息表中没有任何订单的客户,可以利用子查询先从销售信息表中将所有订单的客户id取出来,然后将结果传递给主查询。

select * from custominfo where customId not in (select customId from salesinfo)

利用连接join来实现,速度会更快。

select * from custominfo left join salesinfo on custominfo.customId = salesinfo.customId where salesinfo.customId is NULL

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

sql中连接查询方式有inner join(内连接)、left join(左连接)、right join(有连接)、full join(全连接)四种。

  • inner join:在两张表进行连接查询时,只保留两张表中完全匹配的结果集;
  • left join:在两张表进行连接查询时,会返回左表所有的行,即使在右表中没有匹配的记录;
  • right join:在两张表进行连接查询时,会返回右表所有的行,即使在左表中没有匹配的记录;
  • full join:在两张表进行连接查询时,返回左表和右表中所有没有匹配的行;

4、UNioN代替手动创建临时表

在客户端查询会话结束的时候,临时表会被自动删除,从而保证数据库整齐、高效。使用union来创建查询的时候,我们只需要用union作为关键字把多个select语句连接起来就可以了,要注意的是所有select语句中的字段数目要相同。

select name,phone from client union
select name,birthday from author union
select name,supplier from product

当确认各个select查询不可能出现重复结果集或不在乎重复结果集的时候尽量用union all而不是union,因为union和union all的差异主要是前者需要将两个或多个结果集合并后再进行唯一性过滤,会涉及到排序,增加了cpu运算,和资源消耗。

5、事务

尽管我们可以使用子查询、JOIN和UNION来创建各种各样的查询,但不是所有的数据库操作,都可以只用一条或少数几条就可以完成的。更多的时候是需要用一系列的语句来完成某种工作。但是在这种情况下,当这个语句块中的某一条语句运行出错的时候,整个语句块的操作就会变得不确定起来。要避免这种情况,就出现了事务,要么每条语句都执行成功,要么都失败。

事务以begin关键字开始,commit关键字结束。若其中的一条sql执行失败,那么rollback命令就可以把数据库恢复到begin开始之前的状态。

begin;
update salesinfo set customerId = 1;
update custominfo set name = 'daivid';
commit;

事务必须满足四个条件ACID:

  • 原子性:Atomicity,一个事物(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节;
  • 一致性:Consistency,在事务开始之前和事务结束之后,数据库的完整性没有被破坏;
  • 隔离性:Isolation,数据库允许多个事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同的级别,包括读未提交(Read uncommitted)、读已提交(Read committed)、可重复读(repeateable read)和串行化(Serializable);
  • 持久性:Durability,事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失;

6、索引

索引是提高数据库性能的常用方法。

一般来说,索引应该建立在那些将用于join,where判断和orderby排序的字段上。

尽量不要对数据库中某个含有大量重复的值的字段建立索引,对于一个ENUM类型的字段来说,出现大量重复值是很有可能的情况。

如customerinfo中的“province”…字段,在这样的字段上建立索引将不会有什么帮助;相反,还有可能降低数据库的性能。我们在创建表的时候可以同时创建合适的索引,也可以使用ALTER TABLE或CREATE INDEX在以后创建索引。

避免索引失效的场景:

SELECT * FROM t WHERE YEAR(d) >= 2016;

由于MySQL不像oracle那样支持函数索引,即使d字段有索引,也会直接全表扫描,应改为

SELECT * FROM t WHERE d >= '2016-01-01';
SELECT * FROM t WHERE LOC_ID = 10 OR LOC_ID = 20 OR LOC_ID = 30;

应改为

SELECT * FROM t WHERE LOC_IN IN (10,20,30);
SELECT * FROM t WHERE name LIKE ‘%de%';

应改为

SELECT * FROM t WHERE name LIKE ‘de%';

到此这篇关于Mysql优化方法详细介绍的文章就介绍到这了,更多相关Mysql优化内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql优化方法详细介绍

本文链接: https://www.lsjlt.com/news/194061.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql优化方法详细介绍
    目录1、字段属性2、字段NOT NULL3、JOIN代替子查询4、UNION代替手动创建临时表5、事务6、索引下面聊聊mysql常见的优化方法。 1、字段属性 mysql是一...
    99+
    2023-02-03
    Mysql优化 Mysql优化方法
  • NodeJs操作MYSQL方法详细介绍
    目录在项目中操作数据库的步骤安装与配置 mysql 模块1. 安装 mysql 模块2. 配置 mysql 模块3. 测试 mysql 模块能否正常工作使用 mysql 模块操作 M...
    99+
    2024-04-02
  • Mysql表的操作方法详细介绍
    目录创建表查看表结构修改表删除表创建表 语法: CREATE TABLE table_name ( field1 datatype, field2 datatype, field3 ...
    99+
    2024-04-02
  • MySQL索引优化之分页探索详细介绍
    目录​​MySQL​​索引优化之分页探索案例一案例二​​MySQL​​索引优化之分页探索 表结构 CREATE TABLE `demo` ( `id` int(11) NOT...
    99+
    2024-04-02
  • Android中卡顿优化布局详细介绍
    目录背景实践过程如何渲染界面什么是过度绘制如何查看绘制维度界面优化硬件加速原理总结背景 在当下移动互联网后半场,手机已经是人手必备的设备。App是离用户最近的应用,界面又是最直观影响...
    99+
    2024-04-02
  • fastjson 使用方法详细介绍
    Fastjson介绍Fastjson是一个Java语言编写的JSON处理器。遵循http://json.org标准,为其官方网站收录的参考实现之一。功能qiang打,支持JDK的各种类型,包括基本的JavaBean、Collection、M...
    99+
    2023-05-30
    fastjson 使用
  • 详细介绍mysql表格id清零的方法
    文章目录 方法一:利用TRUNCATE TABLE语句清空表格并重置id方法二:利用ALTER TABLE语句修改自增长id的初始值方法三:利用DELETE语句删除表格中的数据并重置id总结 ...
    99+
    2023-09-30
    mysql 数据库 原力计划
  • mysql事务详细介绍
    目录简介事务四个特性事务隔离级别验证MVCC当前读快照读当前读、快照读、MVCC关系mvcc 解决的问题MVCC实现原理可见性规则简介 事务是由一组sql语句组成的逻辑处理单元 事务...
    99+
    2024-04-02
  • MySQL游标详细介绍
    目录1、什么是游标(或光标)2、如何使用游标1、声明游标2、打开游标3、使用游标4、关闭游标3、代码举例4、小结1、什么是游标(或光标) 虽然我们也可以通过筛选条件 WHERE...
    99+
    2024-04-02
  • $.ajax()方法参数的详细介绍
    本篇内容主要讲解“$.ajax()方法参数的详细介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“$.ajax()方法参数的详细介绍”吧!会灵活的运用ajax的...
    99+
    2024-04-02
  • React Immutable使用方法详细介绍
    目录1. 介绍2. 优缺点3. 对象处理4. 数组处理5. 优化组件渲染6. immutable和redux集合使用1. 介绍 假设当前 redux 的大小为 1G,现在要修改 re...
    99+
    2024-04-02
  • 详细介绍Github的使用方法
    随着互联网技术的不断发展,越来越多的开发者开始加入到开源项目中,Github作为目前全球最大的代码托管平台之一,也成为了开发者们分享、学习、合作的重要工具之一。然而,如何使用Github来进行代码管理、版本控制、协作开发等,还是很多新手开发...
    99+
    2023-10-22
  • Androidwebview加载H5方法详细介绍
    目录1,安卓APP 怎么用webview加载H52,H5怎么调用安卓定义的方法3,安卓怎么调用H5定义的方法这篇文章主要阐述3个知识点 安卓APP 怎么用webview加载H5H5怎...
    99+
    2024-04-02
  • Kotlin扩展方法超详细介绍
    目录前言一、扩展方法1.扩展方法的原型2.扩展方法的使用二、Kotlin扩展方法实现原理三、泛型扩展方法四、扩展属性五、为伴生对象添加扩展六、Kotlin 中常用的扩展七、案例前言 ...
    99+
    2024-04-02
  • Vuex详细介绍和使用方法
    目录一、什么是Vuex二、运行机制三、创建项目1、使用脚手架搭建Vue项目2、安装Vuex3、启动项目4、配置使用Vuex4.1、创建store文件夹4.2、配置全局使用store对...
    99+
    2024-04-02
  • Maven使用方法详及方式详细介绍
    目录Maven简介1、软件开发中的阶段2、Maven能做什么3、没有使用maven怎么管理依赖4、什么是maven约定目录结构maven的使用方式POM文件坐标的概念依赖 depen...
    99+
    2022-11-13
    Maven使用方法 Maven方法 Maven使用方式
  • JavaInheritableThreadLocal用法详细介绍
    目录简介问题复现解决方案源码分析注意简介 本文介绍InheritableThreadLocal的用法。 ThreadLocal可以将数据绑定当前线程,如果希望当前线程的ThreadL...
    99+
    2024-04-02
  • MySQL索引的详细介绍
    这篇文章主要介绍MySQL索引的详细介绍,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、什么是索引?  在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的...
    99+
    2024-04-02
  • Vue路由配置方法详细介绍
    目录手动配置Vue-router环境组件内部跳转路由与传参useRouter,useRoute手动配置Vue-router环境 1、下载包: npm i vue-router --s...
    99+
    2024-04-02
  • Javascript数组的 forEach 方法详细介绍
    目录前言使用forEach注意事项前言 在JavaScript 中数组的遍历 有很多中方法, 其中有一种 使用 foreach 来遍历数组。 mdn官方文档 语法: arr.forE...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作