数据库性能分析mysql_mysql数据库的性能优化分析

影响数据库性能的根源:

1,磁盘I/O读取

2,CPU使用率

3,资源竞争

优化的方式:

1,设计优化

2,操作优化

3,使用其他优化技术

1)设计优化:

分类拆分数据量大的表;

选取最适用的字段属性;

索引设计,为经常查询用到的字段建立索引,避免查询时查找其他重复无用的数据,避免了大范围扫描;

2)操作优化:

锁表操作;

尽量避免子查询,将子查询转化成连接查询;

where子句查询条件尽量少使用运算操作;

A>2与A>=3的效果有很大的区别了,因为A>2时数据库会先找出为2的记录索引再进行比较,而A>=3时ORACLE则直接找到=3的记录索引;

a is not null 改为 a>0 或a>''等,判断字段是否为空一般是不会应用索引的;

a<>0 改为 a>0 or a<0 ,不等于操作符是永远不会用到索引的,因此对它的处理只会产生全表扫描;    YY_BH LIKE '%5400%' 这个条件会产生全表扫描,如果改成YY_BH LIKE 'X5400%' OR YY_BH LIKE 'B5400%' 则会利用YY_BH的索引进行两个范围的查询,性能肯定大大提高;

以下三条sql语句的效果是等效的:

代码如下

复制代码

SELECT * FROM `logs` WHERE id = 1 or id = 2 or id = 3

SELECT * FROM `logs` WHERE id between 1 and 3

SELECT * FROM `logs` WHERE id in (1,2,3)

经过测试性能也是差不多,如果id是一个大数组那么最后一条书写会简单很多,可以利用

WHERE后面的条件顺序影响 ,应该先把范围小的条件放前面,在小范围里面按接下来的条件查找;

3)其他优化技术

使用数据缓存技术,如memcached;

使用静态存储,对一些更新不频繁但经常调用的数据采用静态文本的存储方式;

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

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

相关文章

mysql多实例配置安装_MySQL多实例安装配置方案

一.基本概念MySQL多实例就是&#xff0c;在一台机器上开启多个不同的服务端口(如&#xff1a;3306,3307,3308...)&#xff0c;运行多个MySQL服务进程&#xff0c;这些服务进程通过不同的socket监听不同的端口提供服务。MySQL可以共用一套安全程序&#xff0c;使用不同的my.cnf配…

java趣味_Java趣味分享:try finally

考虑以下四个测试方法&#xff0c;它们会输出什么&#xff1f;public class Test {public static void main(String\[\] args) {System.out.println(test1());System.out.println(test2());System.out.println(test3());System.out.println(test4());}private static int test1…

蛇哥开局两星机器人视频_虎牙粉丝活动落幕,蛇哥骚男夺冠,拿下季军的吃鸡一姐直播却哭了...

近日&#xff0c;在虎牙直播展开了万众瞩目的超级粉丝团活动&#xff0c;这是一档非常考验主播综合实力的活动&#xff0c;不仅需要主播人气高&#xff0c;还要粉丝凝聚力足够强&#xff0c;毕竟是需要粉丝们花一点点钱支持的&#xff0c;路人粉一般都很难做到这点。在经过入围…

java 接口访问权限_详解Java之路(五) 访问权限控制

在Java中&#xff0c;所有事物都具有某种形式的访问权限控制。访问权限的控制等级从最大到最小依次为&#xff1a;public&#xff0c;protected&#xff0c;包访问权限(无关键词)和private。public&#xff0c;protected和private这几个Java访问权限修饰词在使用时&#xff0c;…

java for foreach 效率_Java中LinkedList的fori和foreach效率比较

在《Java中ArrayList的fori和foreach效率比较》中对ArrayList的两种循环方式进行了比较&#xff0c;本次对LinkedList的两种遍历方式进行效率的比较。1. list的元素为自定义的对象自定义的Student类public class Student {private String name;private Integer age;public Stud…

java teechart怎么用_TeeChart使用范例

在窗体上加入TeeChart控件&#xff0c;并通过属性加入4个TLineSeries&#xff0c;分别命名为Series1,Series2,Series3,Series4,并添加一按钮Button1,其Click事件为:procedure TForm1.Button1Click(Sender:TObject);beginSeries1.FillSampleValues(200);Series2.FillSampleValue…

java c标签 if有值_c标签 if else c标签 总结

[b]STL标签用法关键字&#xff1a;JSTL标签、、、、、、、、原来一直没有看过&#xff0c;我说过我是新手&#xff0c;但是好多资料上似乎也不重视 JSTL 。我看项目源代码发现其中使用到了这个标签库&#xff0c;感觉其还真是方便&#xff0c;页面看起来更加清爽。减少了 JAVA …

java多态的两种形式_java核心(八):继承与方法重写、final、多态性的两种描述形式...

一、继承的作用子类继承父类的属性和方法&#xff0c;实现代码的复用&#xff1b;子类扩充自己的标准&#xff0c;实现精细化的类型定义。二、子类构造方法的限制子类在实例化的时候&#xff0c;默认先实例化父类对象&#xff0c;然后再实例化本类对象&#xff1b;子类构造方法…

java bean状态_无状态和有状态企业Java Bean

我将通过Java EE 6教程&#xff0c;我试图了解无状态和有状态会话bean之间的区别。如果无状态会话bean不在方法调用之间保留它们的状态&#xff0c;为什么我的程序执行它的方式&#xff1f;package mybeans;import javax.ejb.LocalBean;import javax.ejb.Stateless;LocalBeanSt…

java 树的数据结构_Java数据结构之树(二叉树)

一、概述1.以二叉树为例熟悉树形结构&#xff0c;二叉树的定义如下&#xff1a;1.1.二叉树&#xff1a;是结点有限的集合&#xff0c;这个集合或者是空&#xff0c;或者由一个根结点或两棵互不相交的称为左子树和右子树的二叉树组成。二叉树是一个递归的定义&#xff0c;从中可…

java 纯面向对象_Java到底是不是一种纯面向对象语言?

原标题&#xff1a;Java到底是不是一种纯面向对象语言&#xff1f;Java——是否确实的 “纯面向对象”&#xff1f;让我们深入到Java的世界&#xff0c;试图来证实它。在我刚开始学习 Java 的前面几年&#xff0c;我从书本里知道了 Java 是遵循 “面向对象编程范式(Object Orie…

java爬虫post 404_POST 后台404错误

今天在开发一个用户信息更新模块的时候遇到了两个问题&#xff1a;1、在我提交form表单的时候我希望在提交表单之后页面不刷新&#xff0c;同时返回更新数据2、向后台POST表单信息的时候&#xff0c;后台显示POST url 404的错误解决第一个问题的使用使用jquery.form的插件进行异…

java防止重复启动bat_java调用exe,及调用bat不成功的解决办法

开门见山的说&#xff0c;文件目录如下想调用123.exe,但是尝试了几次调用不到&#xff0c;然后写了个bat。初始内容如下echo offD:cd test"123.exe"双击可以运行&#xff0c;但是java代码无法调用&#xff0c;怪事。于是&#xff0c;辗转反侧&#xff0c;苦思冥想&am…

freetextbox java_FreeTextBox 增加按钮

红色部分是我自己添加上去的&#xff0c;它默认的文件夹是aspnet_client\FreeTextBox&#xff0c;所以ButtonImage这个属性是指在aspnet_client\FreeTextBox\images里的psn.gif图片。ScriptBlock 当然是指要执行的确JS事件了。其它类型的ToolbarButton有&#xff1a;Bold 加粗…

mysql for 语句执行顺序_MySQL使用profile分析SQL语句执行过程

分析SQL执行带来的开销是优化SQL的重要手段。在MySQL数据库中&#xff0c;可以通过配置profiling参数来启用SQL剖析。该参数可以在全局和session级别来设置。对于全局级别则作用于整个MySQL实例&#xff0c;而session级别紧影响当前session。该参数开启后&#xff0c;后续执行的…

java jdbc 操作_Java:JDBC操作

内容&#xff1a;供程序员调用的接口与类&#xff0c;集成在java.sql和javax.sql包中&#xff0c;如&#xff1a;DriverManager类Connection接口Statement接口ResultSet接口1.Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");2.Connection conn Dri…

java 线程 函数_java – 从后台线程调用主线程上的函数

更新我已经更新了这个问题,使用建议的SwingWorker类包含Java实现的源代码,以实现与Objective-C示例相同的结果.希望这将有助于未来的冒险家.Document myDoc ...;Model myModel ...;SwingWorker analyzeDocument new SwingWorker() {Overridepublic Dictionary doInBackgroun…

java se5和8_javaSE_8系列博客——Java语言的特性(三)--类和对象(5)--定义方法...

以下是一个典型的定义一个方法的示例&#xff1a;public double calculateAnswer(double wingSpan, int numberOfEngines,double length, double grossTons) {//do the calculation here}方法声明的唯一必需元素是方法的返回类型&#xff0c;名称&#xff0c;一对括号()和大括号…

下面选项中不是开发java程序的步骤是_Java基础试题及其答案2

Java试题1) java程序中&#xff0c;main方法的格式正确的是()。(选择一项)a)static void main(String[] args)b)public void main(String[] args)c)public static void main(String[]s)d)public static void main(String[] args)2)给定java代码&#xff0c;如下&#xff1a;pub…

java java.doc_使用 javadoc 自动生成 Java 文档

Java 的注释&#xff0c;单行&#xff0c;多行的语法就不在赘述了。javadoc tags给 Java 源码文件书写注释&#xff0c;使用常见的 Java 注释可以实现一些&#xff0c;也可以通过如下的 Javadoc 的 Tags 来实现一些特殊的比如跳转&#xff0c;参数返回值等特殊标记。javadoc 标…