易截截图软件、单文件、免安装、纯绿色、仅160KB

SQL优化( 引用 )



 
SQL优化查询
收藏



数据库的查询优化技术
数据库系统是管理信息系统的核心,基于数据库的联机事务处理(OLTP)以及联机分析处理(OLAP)是银行、企业、政府等部门最为重要的计算机应
用之一。从大多数系统的应用实例来看,查询操作在各种数据库操作中所占据的比重最大,而查询操作所基于的SELECT语句在SQL语句中又是代价最大的语
句。举例来说,如果数据的量积累到一定的程度,比如一个银行的账户数据库表信息积累到上百万甚至上千万条记录,全表扫描一次往往需要数十分钟,甚至数小
时。如果采用比全表扫描更好的查询策略,往往可以使查询时间降为几分钟,由此可见查询优化技术的重要性。
笔者在应用项目的实施中发现,许多程序
员在利用一些前端数据库开发工具(如PowerBuilder、Delphi等)开发数据库应用程序时,只注重用户界面的华丽,并不重视查询语句的效率问
题,导致所开发出来的应用系统效率低下,资源浪费严重。因此,如何设计高效合理的查询语句就显得非常重要。本文以应用实例为基础,结合数据库理论,介绍查
询优化技术在现实系统中的运用。
分析问题
许多程序员认为查询优化是DBMS(数据库管理系统)的任务,与程序员所编写的SQL语句关
系不大,这是错误的。一个好的查询计划往往可以使程序性能提高数十倍。查询计划是用户所提交的SQL语句的集合,查询规划是经过优化处理之后所产生的语句
集合。DBMS处理查询计划的过程是这样的:在做完查询语句的词法、语法检查之后,将语句提交给DBMS的查询优化器,优化器做完代数优化和存取路径的优
化之后,由预编译模块对语句进行处理并生成查询规划,然后在合适的时间提交给系统处理执行,最后将执行结果返回给用户。在实际的数据库产品(如
Oracle、Sybase等)的高版本中都是采用基于代价的优化方法,这种优化能根据从系统字典表所得到的信息来估计不同的查询规划的代价,然后选择一
个较优的规划。虽然现在的数据库产品在查询优化方面已经做得越来越好,但由用户提交的SQL语句是系统优化的基础,很难设想一个原本糟糕的查询计划经过系
统的优化之后会变得高效,因此用户所写语句的优劣至关重要。系统所做查询优化我们暂不讨论,下面重点说明改善用户查询计划的解决方案。
解决问题

下面以关系数据库系统Informix为例,介绍改善用户查询计划的方法�


相关文档:

SQL Azure vs SQL Server

公告:本博客为微软云计算中文博客的镜像博客,并不保证链接可用性,为了保证阅读体验,请访问http://blogs.msdn.com/azchina。
 
 
SQL Azure vs. SQL Server
概要
SQL Azure Database 是一个来自微软的,基于云的关系型数据库服务。SQL Azure 提供关系型数据库功能来作为公用服务。基于云的数据库解决方案 ......

如何链接到Sql Server 2005


SQL Server 2005
本篇介绍如何链接到Sql Server 2005.
采用SQL 本地客户 ODBC驱动
采用Sql身份验证
Driver={SQL Native Client};Server=myServerAddress;Database=myDataBase;Uid=myUsername;Pwd=myPassword;
你正在使用SQL Server 2005 Express?别忘记了,Servername的语法是Servername\SQLEXPRESS,你可以用你安� ......

jsp与SQL Server 2000 的连接

终于搞定JSP连接SQL Server 2000数据库的问题了
2008年01月29日 星期二 15:54
    前几天,平平同学一直在搞JSP 连接SQL Server 2000数据库的问题,一直连不上,然后叫我去帮他看看,凭着以前的经验,搞了一个下午,嘿嘿!终于帮他连接上了,主要步骤如下:
    1、需要的东西大家可以到� ......

sql 语句处理 日期处理

DATENAME([Year],
      dbo.reservation.begintime) + N'年' + CAST(DATEPART([Month],
      dbo.reservation.begintime) AS varchar) + N'月' + DATENAME([Day],
      dbo.reservation.begintime) + N'日' + DATENAME([Hour], dbo.r ......

sql server的复制和订阅

      最近遇到一个项目,客户在总部录入信息后,数据需要同步到下属的若干个子系统中。现在总部单独使用一个数据库,下属单位各自使用自己的数据库。
      对于这个问题,想到了几个解决方案:
     1、自己写代码解决。定义好访问每个数� ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号