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,一经查实,立即删除!

相关文章

linux mysql 目录结构图_linux下mysql安装、目录结构、配置

1、准备安装程序(官方网站下载)服务端:MySQL-server-community-5.1.44-1.rhel4.i386.rpm客户端:MySQL-client-community-5.1.44-1.rhel4.i386.rpm2、安装(打印信息略)[rootlocalhost /]#rpm -ivh MySQL-server-community-5.1.44-1.rhel4.i386.rpm;[rootl…

php mysql删除失败_php mysql删除的代码哪里出错了?

<?phpsession_start ();if($_SESSION[droits]f){echo("vousn\avezpasdedroit");}include(dirname(__FILE__)."/includes/connexion.php");?>-//W3C//DTDHTML4...session_start();if ($_SESSION[droits] f){echo("vous n\avez pas de droit&q…

mysql rr 更新失败_RR 级别下 update 操作的是快照读还是当前读?

我们知道在 RR 级别下&#xff0c;重复的 select 操作&#xff0c;读取的值都会是一致的。即便在两次 select 操作的中间&#xff0c;有一个事务 B 修改了值&#xff0c;但是在事务 A 中 select 读取的值还是一致的。那么如果是 update 操作呢&#xff1f;之前在网上看到一篇博…

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

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

python中数据类型不同运算不同_Python的基本数据类型与运算

Python的基本数据类型:1.number数字整型(整数):python可以处理任意大小的整数包括正整数与负整数浮点型(小数):在Python中表示浮点数的时候回存在一些误差复数:abj2.str字符串类型定义:使用单引号或者双引号括起来的任意文本,我们称之为字符串.3.bool(布尔)类型取值只有Ture和F…

ubuntu 自动加载ko_linux驱动模块开机自动加载,以及应用程序开机自启动

http://blog.csdn.net/qq_29350001/article/details/51788635第一种方法&#xff1a;相对来说简单将测试程序放在/bin底下&#xff0c;然后用vi编辑/etc/init.d/rcS&#xff0c;加上/bin/应用程序名 &,加上&表示后台运行这两个功能的实现都是通过设置启动脚本来实现的。…

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

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

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

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

树莓派 pip安装mysql_树莓派 pip 手动安装

在 /etc/pip.conf 添加如下内容&#xff0c;启用源[global]extra-index-urlhttps://www.piwheels.org/simple下载后 pip install **.whl 安装国内源&#xff1a;新版ubuntu要求使用https源&#xff0c;要注意。清华&#xff1a;https://pypi.tuna.tsinghua.edu.cn/simple阿里云…

6阶群的非平凡子群_设群G=Z 16 , 求出其全部非平凡正规子群和相应的商群._学小易找答案...

【计算题】求出三次对称群 的全部正规子群和商群。【单选题】19、如下图所示,已知主、俯视图,正确的俯视图为( )【单选题】7、一平面在W面上的投影是一条平行于OZ轴的直线,在H面上的投影是一条平行于OX轴的直线,该直线是( )。【单选题】1、已知点N(15,22,10),下列说法错误的是(…

fastjson 不转某些字段_全面总结Fastjson过滤字段、排除字段的5种方法(含示例)...

1.通过注解指定不需要序列化的字段在不需要序列化的字段&#xff0c;添加JSONField(serialize false)注解可进行排除。public class DontSerializeAnnotation{JSONField(serialize false)private Long id;private String name;public Long getId(){return id;}public void se…

qpython3h安装numpy_怎么装不上numpy?

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼还是不行&#xff1a;(------------------------------------------------------------ /data/data/com.hipipal.qpyplus/files/bin/pip run on Mon Sep 21 11:04:21 2015 Downloading/unpacking numpy Running setup.py egg_info …

java随机整数_java如何产生1-8的整数随机数?

展开全部(int)(Math.random()*8)1或者Random r new Random(100);System.out.println(r.nextInt(8)1);Java产生随机数的两种方式62616964757a686964616fe58685e5aeb9313333656462611、通过Math.random()方法返回一个0到1之间的double值。2、通过Random类来产生一个随机数&#x…

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 音频解码_java视频音频解码-封装xuggle-实现多种视频编码格式解码扩展

手头做一个视频相关项目&#xff0c;但是客户发来的测试视频(avi格式) 现有组件不能解码。现有视频解码组件方案有基于JMF和opencv Jni调用。远远不能满足目前市面上玲琅满目的各种视频编码标准。进行检索 找到xuggler官方主页&#xff1a;http://www.xuggle.com/xuggler 对5.…

java 二叉树特点_二叉树的Java实现及特点总结

二叉树是一种非常重要的数据结构&#xff0c;它同时具有数组和链表各自的特点&#xff1a;它可以像数组一样快速查找&#xff0c;也可以像链表一样快速添加。但是他也有自己的缺点&#xff1a;删除操作复杂。我们先介绍一些关于二叉树的概念名词。二叉树&#xff1a;是每个结点…

java中session的作用_java中session的工作原理是什么?和Cookies有何区别?

现在大家学习的东西和以前大不相同了&#xff0c;越来越多的人倾向于去学习高新技术以获得更好的发展。java是很多人的第一选择。java中的知识还是很多的&#xff0c;今天就来为大家介绍一下。首先来说一下java中session的工作原理是什么?session的工作原理是客户端登录完成之…

java 大数四则运算_大数四则运算java(转)

1 //大数的四则运算2 #include 3 #include 4 #include 5 using namespace std;67 classBIGINTEGEROPERATIONS8 {9 private:10 static intCOMPARE(string number1, string number2)11 {12 intj;1314 int length1 number1.size();15 int length2 number2.size();1617 if(number1.…

http参数自动转换java接口参数设置_Springmvc请求参数类型转换器及原生api代码实例...

一、springmvc的xml配置文件xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xmlns:context"http://www.springframework.org/schema/context"xmlns:mvc"http://www.springframework.org/schema/mvc"xsi:schemaLocation"http://www.s…

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

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