mysql数据库优化语句_mysql数据库优化语句

mysql优化语句数据库语句: Ddl(数据定义语言) alter create drop Dml(数据操作语言) inset delete update www.2cto.com Dtl(数据事务语言) conmmit rollback savepoint Select Dcl(数据控制语句) grant赋权限 revoke回收 Mysql数据库优化: 1、 数据库表

mysql优化语句

数据库语句:

Ddl(数据定义语言)    alter  create   drop

Dml(数据操作语言)   inset  delete  update

www.2cto.com

Dtl(数据事务语言)  conmmit  rollback   savepoint

Select

Dcl(数据控制语句) grant赋权限  revoke回收

Mysql数据库优化:

1、  数据库表 要设计合理(符合3NF,有时候也需要适当的逆范式)

2、  Sql语句的优化(索引,常用小技巧)

3、  数据库的配置

4、  适当的硬件配置和操作系统

5、  读写分离

问:什么是数据库3范式?

1NF: 就是具有原子性,不可分割(只要使用的是关系型数据库,就会自动符合)

2NF: 在满足1NF的基础上,我们考虑是否满足2NF,只要表的记录满足唯一性,也就是说,你的同一张表中不可能出现完全相同的记录,一般说我们在表中设计一个主键即可。

3NF: 在满足2NF: 的基础上,我们考虑是否满足3NF,既我们的字段信息可以通过关联的关系,派生即可(通常我们通过外键来处理)使用外键数据库的存储引擎必须是innoDB

问2:数据库参数配置

对于innodb存储引擎最重要的就是内存,所以下面的两个参数调的很大

Innodb_additional_mem_pool_size = 64M    www.2cto.com

Innodb_buffer_pool_size = 1G     缓冲池大小

对于myisam,需要调整key_buffer_size

用show  status 语句可以看到当前状态,以决定调整那些参数

一、显示你使用过多少次insert  , update   ,  delete 等

Sql:    show status  like  “Com”;

//在命令窗口中不关闭的时候查询会准确,如果关闭就会从新开始统计

Show sessionstatus like “Com_update”;

//就算关闭窗口也会将全部的你执行过的次数统计出来

Show globalstatus like “Com_insert”;

Example:  session

假如已经使用了6次update

1、  用session统计 会是6次

如果关闭后命令窗口后在执行Show session statuslike “Com_update”;  就为0了

2、  但是如果用Show global status like “Com_insert”;就是6次

二、显示试图连接Mysql服务器的次数

Show  status like  “Connections”;

数据库启动多长时间了

Show  status like   “uptime”;

显示慢查询多少次(默认是10秒)

Show  status like  “Slow_queries”;

四、如何在一个项目中,找到慢查询的select,数据库支持把慢查询的语句记录到日志中,供程序员来分析  www.2cto.com

步骤:

1、 启动mysql(特殊的启动方式)

a)        在mysql的安装目录下的bin目录下启动mysqld.exe –slow-query

b)       Netstat –an 查看3306端口是否启动

c)        查询慢查询的次数   show status  like  “Slow_queries”;

d)       设置慢查询的时间   set long_query_time=1;

索引优化:

比如说增加主键索引

Alter  table user   add  primary key(id);

删除主键索引

Alter  table user  drop  primary key

删除索引

Alter  table  user drop  index   索引名

显示索引

Show  index(es)  from  表名

Show  keys  from  表名

Desc  表名

增加索引致使查询会变快好多,其原理就像一本书如果没有目录的话那么如果你想找一个知识点会很难找到,只能一点一点的翻着找,如果有目录的话会很快的定位到这个知识点在那个章节中大概什么位置这样查询起来自然就会快了啊,但是有利必有弊,索引会对查询带来好处,但是对add   update   delete  来说自然就很麻烦了,比如说你添加一个知识点,你不许还有在目录中添加他是属于那章那节中的那个知识点,同样在修改和删除的时候也会随之改变,来保持信息的准确性。

7a70963b921a998722b3f5b0c79ed9bb.png                                                                                                                 

一个自动分析是否需要使用索引的命令:explain

Example:  explain  select  *  from emp   where   id  =   9;

9b8fb5ad54bdf0d48bf68127adf8a4a1.png

索引的分类:

主键索引(primary   key)

唯一键索引(unique)

Index(普通索引)

全文索引(fulltext)

复合索引(多列和在一起)

www.2cto.com

在那些列上添加索引比较合适:

1、比较频繁的作为查询条件的字段应该加上索引

2、  唯一性比较差的字段不适合单独创建索引,及时频繁作为查询条件

3、  更新非常频繁的字段不适合创建索引

4、  不会出现在where子句中的字段不该创建索引

查询一个表中的所有索引: show  indexes   from  table(表名)

索引的使用:

查询要使用索引最重要的条件是查询条件中需要使用索引

以下几种情况可能会使用到索引

1、  对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用

2、  对于使用like的查询,查询如果是‘%aaa’不会使用到索引‘aaa%’会使用到索引

以下的表中将不使用索引

1、  如果条件中有or,即使其中有条件带索引也不会使用

2、  对于多列索引,不是使用的第一部分,则不会使用索引

3、  Like查询是以%开头

4、  如果列类型是字符串,那么一定要在条件中将数据使用引号引起来,否则不使用索引。

5、  如果mysql估计使用全表扫描要比使用索引快,则不使用索引。

查看索引的使用情况

Show status  like   ‘handler_read%’;

48c8180aca3ed7845145f1becfe92d90.png

只有handler_read_key  越大越好

Handler_read_rnd_next  越小越好

数据库类型:

MyISAM  不支持事务和外键,一张表由三个文件组成,.frm  .myi  .myd

innoDB    支持事务和外键

对于MyISAM来说查询快,不过删除字段时空间是不会释放的,必须使用手动释放        optimize   table  table_name  www.2cto.com

数据库分表:

1、  水平分表

6b31ec45639d4fcaa72ab9550168be4b.png

2、  垂直分表:

Stu表:

id

Name

Pass

Photo

Mark表

Id

Sid

Question

answer

垂直分表针对于关联类型的表,比如说,有一个学生的个人信息(有头像)表,一个考试信息(考试题和答案)表,这时我想查一个学生的考试分数和个人信息,那么mysql会将学生的个人信息和考试信息表关联,速度回降低很多,所以要将考试信息中的答案和题目分开在创建一个表,如果在提高还可以将头像分开为一个单独的表(如百度单独的图片服务器)

读写分离:

8ec0ce7c4e18f961f3f572294dc376a2.png

作者 web8

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

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

相关文章

json模拟数据怎么用_在使用axios获取自己模拟的json数据是踩到的坑

最近在使用Vue仿写一个网易云音乐的单页面应用,当页面布局什么的写完后,然后就准备用axios获取后台数据渲染页面了,当然,我自己写的,并没有后台,所以,我就自己写json文件,然后弄prox…

mysql架构深入_mysql性能优化2:深入认识mysql体系架构

前言本文将重点梳理mysql的体系架构,便于了解mysql的实现原理。Mysql体系结构Client Connectors 接入方 支持协议很多Management Serveices & Utilities 系统管理和控制工具,mysqldump、 mysql复制集群、分区管理等Connection Pool 连接池&#xff1…

mysql租车管理系统_基于java实现租车管理系统

概述基于java swing JFrame 的图书馆管理系统,租车,还车,管理员管理用户,付款等。部分代码public class Login extends JFrame {private static final long serialVersionUID 1L;/*** 登录窗体*/public Login() {setDefaultClo…

java 1的阶乘之和_1-20的阶乘之和(java)

import java.math.BigInteger;public class Factorial {//2)求1&#xff01;2&#xff01;……20&#xff01;public static void main(String[] args){BigInteger sumBigInteger.ZERO;for(BigInteger iBigInteger.ONE;i.intValue()<20;){ii.add(BigInteger.ONE);sumsum.add…

java构建json_Java构造和解析Json数据的两种方法详解一

在www.json.org上公布了很多JAVA下的json构造和解析工具&#xff0c;其中org.json和json-lib比较简单&#xff0c;两者使用上差不多但还是有些区别。下面首先介绍用json-lib构造和解析Json数据的方法示例。用org.son构造和解析Json数据的方法详解请参见我下一篇博文&#xff1a…

java final被覆盖_java中的final的使用

1、final类不能被继承&#xff0c;因此final类的成员方法没有机会被覆盖&#xff0c;默认都是final的。在设计类时候&#xff0c;如果这个类不需要有子类&#xff0c;类的实现细节不允许改变&#xff0c;并且确信这个类不会再被扩展&#xff0c;那么就设计为final类。(什么时候…

wordcount.java_mapreduce中wordcount的java实现

用java模拟词频统计。有3个文件&#xff1a;text1: hello worldtext2:hello hadooptext3:hello mapreduce对上面的文件进行词频统计&#xff1a;结果应该是&#xff1a;hello:3; hadoop:1; world:1; mapreduce:1代码实现如下&#xff1a;package count;import java.ut…

java程序回滚之后在哪看_Java在触发事务回滚之后为什么会再一次回到Servlet开始的地方重新走一次流程?...

代码流程前台点击"提交订单"进入BaseServlet.classBaseServlet.class分发至子类OrderServlet.class的submitOrder()方法submitOrder()调用Service层的submitOrder()方法.关键是Service层submitOrder()中使用了事务回滚. 这里调用了Dao层两个方法: fun01()和fun02(), …

java不进入for_为什么阿里巴巴Java开发手册中强制要求不要在foreach循环里进行元素的remove和add操作?...

在阅读《阿里巴巴Java开发手册》时&#xff0c;发现有一条关于在 foreach 循环里进行元素的 remove/add 操作的规约&#xff0c;具体内容如下&#xff1a;错误演示我们首先在 IDEA 中编写一个在 foreach 循环里进行 remove 操作的代码&#xff1a;import java.util.ArrayList;i…

8086汇编4位bcd码_二进制格雷码与自然二进制码的互换分析

在精确定位控制系统中&#xff0c;为了提高控制精度&#xff0c;准确测量控制对象的位置是十分重要的。目前&#xff0c;检测位置的办法有两种&#xff1a;其一是使用位置传感器&#xff0c;测量到的位移量由变送器经A/D转换成数字量送至系统进行进一步处理。此方法精度高&…

软件工程结构化建模的方法和工具_软件工程系列-结构化设计方法2

本系列文章为笔记&#xff0c;内容根据北京大学《软件工程》MOOC 初始化模块结构图精化的启发式规则常见的启发式规则什么叫做“启发式”根据设计准则&#xff0c;从长期的软件开发实践中&#xff0c;总结出来的规则既不是设计目标&#xff0c;也不是设计时应该普遍遵循的原理常…

java四种权限的高低_Java(四种权限修饰符)

/*Java中有四种权限修饰符&#xff1a;public > protected > (default) > private同一个类(我自己) YES YES YES YES同一个包(我邻居) YES YES YES NO不同包子类(我儿子) YES YES NO NO不同包非子类(陌生人) YES NO NO NO注意事项&#xff1a;(default)并不是关键字“…

安全扫描失败无法上传_Apache Solr 未授权上传(RCE)漏洞的原理分析与验证

漏洞简介Apache Solr 发布公告&#xff0c;旧版本的ConfigSet API 中存在未授权上传漏洞风险&#xff0c;被利用可能导致 RCE (远程代码执行)。受影响的版本&#xff1a;Apache Solr6.6.0 -6.6.5Apache Solr7.0.0 -7.7.3Apache Solr8.0.0 -8.6.2安全专家建议用户尽快升级到安全…

php session页面传值,PHP session在页面间传递的问题

PHP session在页面间传递的问题:前提: 使用codeIgniter的框架, 使用PHP自带的session1. 在纯apache服务器上没有问题2. 在Nginx的apache模式下, 独立于codeIgniter框架外的页面无问题3. 在Nginx的apache模式下, 置于codeIgniter框架内的页面, 页面间session的传递有问题, 即一个…

html5怎么改为vue_Vue实战——编程式导航打开新窗口,登录状态本地存储

近日来&#xff0c;我陆续的分享了vue相关的系列文章&#xff0c;以新闻列表项目为载体&#xff0c;实战的方式介绍了vue及其周边的技术。本文承接前文&#xff0c;不断通过项目迭代的方式继续分享vue相关的知识。目前Vue实战系列文章已形成了目录&#xff0c;各位感兴趣的朋友…

python转cpp_python转c工具

广告关闭 腾讯云11.11云上盛惠 &#xff0c;精选热门产品助力上云&#xff0c;云服务器首年88元起&#xff0c;买的越多返的越多&#xff0c;最高返5000元&#xff01; compute.proto # python_out目录指定 xxxx_pb2.py的输出路径&#xff0c;我们指定为. 当前路径# grpc_pytho…

80端口为什么要备案_搞网站的你,不了解一下共享虚拟主机和备案问题

正文共&#xff1a;1474字 14图&#xff0c;预估阅读时间&#xff1a;4 分钟今天分享的这一切要从域名备案说起。先科普一下&#xff0c;平时我们访问网站都是用域名访问的&#xff0c;通过DNS服务器将域名解析为IP地址(你知道上网时输入的URL是怎么解析成IP地址的吗&#xff1…

jqprint获取打印页数_高年级应用题40道,假期快给孩子打印练习吧!(含答案)...

1.王爷爷家养的4头奶牛每个星期产奶896千克&#xff0c;平均1头奶牛每天产多少奶呢&#xff1f;2.4辆汽车3次运水泥960袋&#xff0c;平均每辆汽车每次运水泥多少袋&#xff1f;3.水波小学每间教室有3个窗户&#xff0c;每个窗户安装12块玻璃&#xff0c;9间教室一共安装多少块…

cstring移除指定字符串_从String中移除空白字符的多种方式!?差别竟然这么大!...

作者 | Hollis来源 | Hollis字符串&#xff0c;是Java中最常用的一个数据类型了。我们在日常开发时候会经常使用字符串做很多的操作。比如字符串的拼接、截断、替换等。这一篇文章&#xff0c;我们介绍一个比较常见又容易被忽略的一个操作&#xff0c;那就是移除字符串中的空格…

matlab 遗传优化算法_转载 | 遗传算法解决TSP问题的MATLAB实现

问题定义&#xff1a;巡回旅行商问题给定一组n个城市和俩俩之间的直达距离&#xff0c;寻找一条闭合的旅程&#xff0c;使得每个城市刚好经过一次且总的旅行距离最短。TSP问题也称为货郎担问题&#xff0c;是一个古老的问题。最早可以追溯到1759年Euler提出的骑士旅行的问题。1…