解决SQL速度慢的方法_MySQL
作者:汜水 | 来源:互联网 | 2017-05-12 16:09
下面是我多年经验的总结:网络编程总要和数据库打交道。和数据库打交道总要接触到SQL。如何使你的SQL跑得快一点,本文介绍几种行之有效的方法:方法一、尽量使用复杂的SQL来代替简单的一堆SQL.同样的事务,一个复杂的SQL完成的效率高于一堆简单SQL完成的效率。有多
下面是我多年经验的总结: 网络编程总要和数据库打交道。和数据库打交道总要接触到SQL。如何使你的SQL 跑得快一点,本文介绍几种行之有效的方法: 方法一、尽量使用复杂的SQL来代替简单的一堆SQL. 同样的事务,一个复杂的SQL完成的效率高于一堆简单SQL完成的效率。有多个查询时,要善于使用JOIN。 oRs=objDBC.Execute(‘SELECT * FROM Books‘) for(; !oRs.Eof; oRs.MoveNext()) { oRs2=objDBC.Execute(‘SELECT * FROM Authors WHERE AuthorID=‘‘ oRs (‘AuthorID‘).value ‘‘‘); Response.write(oRs(‘Title‘).value ‘ ‘ oRs2(‘Name‘) ‘
‘); } 要比下面的代码慢: oRs=objDBC.Execute(‘SELECT Books.Title,Authors.Name FROM Books JOIN Authors ON Authors.AuthorID=Books.AuthorID‘); for(; !oRs.Eof; oRs.MoveNext()) { Response.write(oRs(‘Title‘).value ‘ ‘ oRs(‘Name‘) ‘
‘); } 方法二、尽量避免使用可更新Recordset oRs=objDBC.Execute(‘SELECT * FROM Authors WHERE AuthorID=17‘,(some flags)); oRs(‘Name‘)=‘Karl Karlsson‘; oRs.Update(); 要比下面的代码慢: objDBC.Execute(‘UPDATE Authors SET Name=‘Karl Karlsson‘ WHERE AuthorID=17‘); 方法三、更新数据库时,尽量采用批处理更新将所有的SQL组成一个大的批处理SQL,并一次运行;这比一个一个地更新数据要有效率得多。这样也更加满足你进行事务处理的需要: (in JScript) strSQL=‘‘; strSQL =‘SET XACT_ABORT ON\n‘; strSQL =‘BEGIN TRANSACTION\n‘; strSQL =‘INSERT INTO Orders(OrdID,CustID,OrdDat) VALUES(‘9999‘, ‘1234‘,GETDATE())\n‘; strSQL =‘INSERT INTO OrderRows(OrdID,OrdRow,Item,Qty) VALUES(‘9999 ‘,‘01‘,‘G4385‘,5)\n‘; strSQL =‘INSERT INTO OrderRows(OrdID,OrdRow,Item,Qty) VALUES(‘9999 ‘,‘02‘,‘G4726‘,1)\n‘; strSQL =‘COMMIT TRANSACTION\n‘; strSQL =‘SET XACT_ABORT OFF\n‘; objDBC.Execute(strSQL); 其中,SET XACT_ABORT OFF 语句告诉SQL Server,如果下面的事务处理过程中,如果遇到错误,就取消已经完成的事务。 方法四、数据库索引 方法五、避免使Text字段太大当字符串的值大小不固定时,用varchar比用char的效果要好些。我曾经看到一个例子程序,字段被定义为TEXT(255),但是他的取值经常只有20个字符。这个数据表有50k个记录,从而使这个数据库很大,大的数据库必然较慢。
推荐阅读
-
本文详细介绍了通过优化SQL查询策略,成功将一张包含955万条记录的财务流水表的查询时间从17秒缩短至300毫秒的方法。文章不仅提供了具体的SQL优化技巧,还深入探讨了背后的数据库原理。 ...
[详细]
蜡笔小新 2024-11-21 12:11:54
-
本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ...
[详细]
蜡笔小新 2024-11-21 09:45:56
-
-
本文记录了在Windows 8.1系统环境下,使用IIS 8.5和Visual Studio 2013部署Orchard 1.7.2过程中遇到的问题及解决方案,包括503服务不可用错误和web.config配置错误。 ...
[详细]
蜡笔小新 2024-11-20 16:51:36
-
在处理大量联系人数据的批量插入操作时,发现现有方法的执行效率低下,尤其是在处理数十条记录以上时,与导出操作的速度形成鲜明对比。本文将探讨如何通过代码优化来提升批量插入联系人的效率。 ...
[详细]
蜡笔小新 2024-11-20 14:55:21
-
蜡笔小新 2024-11-20 14:27:32
-
在处理大数据量的SQL分页查询时,通常需要执行两次查询来分别获取数据和总记录数。本文介绍了一种优化方法,通过单次查询同时返回分页数据和总记录数,从而提高查询效率。 ...
[详细]
蜡笔小新 2024-11-20 13:54:29
-
本文探讨了在流处理中进行计数的各种技术和挑战,并基于作者在2016年圣何塞举行的Hadoop World大会上的演讲进行了深入分析。文章不仅介绍了传统批处理和Lambda架构的局限性,还详细探讨了流处理架构的优势及其在现代大数据应用中的重要作用。 ...
[详细]
蜡笔小新 2024-11-20 13:50:01
-
本文深入探讨了Bootstrap Paginator这款流行的JavaScript分页插件,提供了详细的使用指南和示例代码,旨在帮助开发者更好地理解和利用该工具进行高效的数据展示。 ...
[详细]
蜡笔小新 2024-11-20 13:39:53
-
本文将详细介绍Mybatis Plus框架中@TableField注解的具体使用方法及其应用场景,帮助开发者更好地理解和利用这一强大工具进行高效的数据操作。 ...
[详细]
蜡笔小新 2024-11-20 13:11:19
-
湖上湖返回与带有给定字符串名的类或接口相关联的Class对象。调用此方法等效于:Class.forName(className,true,currentLoader) ...
[详细]
蜡笔小新 2024-11-20 12:55:32
-
本文介绍了如何使用SQL命令查看数据库中特定表的创建结构,这对于数据库管理和维护非常有用。文章还提供了一些额外的技巧和最佳实践。 ...
[详细]
蜡笔小新 2024-11-20 12:10:12
-
flea,frame,db,使用,之 ...
[详细]
蜡笔小新 2024-11-20 12:00:16
-
本文介绍了如何在两个Oracle数据库(假设为数据库A和数据库B)之间设置DBLink,以便能够从数据库A中直接访问和操作数据库B中的数据。文章详细描述了创建DBLink前的必要准备步骤以及具体的创建方法。 ...
[详细]
蜡笔小新 2024-11-20 11:20:35
-
本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ...
[详细]
蜡笔小新 2024-11-20 10:58:03
-
本文详细介绍了Hibernate中的立即检索与延迟检索的概念及区别,同时探讨了类级别与关联级别的检索配置方法。通过具体的配置示例,帮助开发者更好地理解和应用这些策略。 ...
[详细]
蜡笔小新 2024-11-20 10:03:01
-