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

SQL 分页查询效率

用T-SQL做数据库分页查询也有好几年了,但对于各种查询方法的写法一至都没怎么去理会,最近参与了几个项目的开发,几个项目中分页查询的写法也不相同,这也让我产生了确认几种写法效率问题的兴趣。(注:我所说的几种写法都是需要返回总记录数的分页)
1、生成测试数据
select a.* into test from sys.columns a,sys.columns b
本机生成5564881行数据,相信也够多了吧。
主要说两种写法:
第一种:  分两个查询,先按查询条件查询出总记录数,再写一相同查询取出页数据;
第二种:将查询结果写入临时表,然后统计总记录数,再根据分页索引取出页数据; 
第一种写法SQL:
select count(*) from test where [name] like 'ActivityID' and max_length>1
 select * from(
 select a.[object_id],row_number() over(order by object_id) as rowIndex from test a
   where [name] = 'ActivityID' and max_length>1
 )t
 where rowIndex>100 and rowIndex<200
第二种写法SQL:
select a.[object_id],row_number() over(order by object_id) as rowIndex into #t from test a
  where [name] = 'ActivityID' and max_length>1
 
 select * from #t where rowIndex>100 and rowIndex<200
 select count(*) from #t
 drop table #t
测试结果:
当where 条件只有一个是,查询一性能优于查询二;但增加一条件后查询二性能优于查询一;
总结一下:
1、第一种写法优势在于I/O开销小于第二种写法,由其在满足条件返回数据越多的情况下性能越优;
2、第二种写法在查询条件复杂查询下性能优于第一种写法;
另外在使用Like 和=时一定要注意,=性能高于Like,在不使用通配符的情况下应使用=;(汗一个自己,以前习惯性的使用Like,这个习惯要好好的改一下了。)


相关文档:

SQL Server 2008 R2 应用及多服务器管理

     在激烈的市场竞争环境下,商人对市场环境的把握和决策直接关系到市场的趋势和机遇,对客户需求的快速相应能够占尽市场的先机。在当今社会的日常商务活动中,以往积累的相关商业数据能够为后续的业务活动提供良好的参考和向导。早在10余年前,商业智能(Business Intelligence,下称BI)厂商就已经 ......

操作数据库结构的常用Sql命令(2)

操作数据库结构的常用Sql
下面是Sql Server 和 Access 操作数据库结构的常用Sql,内容由海娃整理,不正确与不完整之处还请提出,谢谢。
新建表:
create table [表名]
(
[自动编号字段] int IDENTITY (1,1)  PRIMARY KEY ,
[字段1] nVarChar(50) default '默认值' null ,
[字段2] ntext null ,
[字段3] dateti ......

SQL里的主键和外键

这个逻辑关系乍看起来比较复杂,弄清楚了就好!
有两个表,
student(
id,
name,
primary key (id)
);
studentInfo(
id,
age,
address,
foreign key(id) references outTable(id) on delete cascade on update cascade
);
当我们删除student表的时候自然希望studentInfo里的相关信息也被删除,这就是外键起作用 ......

sql server中常见的函数的用法

SQL字符串函数http://www.cnblogs.com/virusswb/archive/2008/09/10/1288576.html
select语句中只能使用sql函数对字段进行操作(链接sql server),
select 字段1 from 表1 where 字段1.IndexOf("云")=1;
这条语句不对的原因是indexof()函数不是sql函数,改成sql对应的函数就可以了。
left()是sql函数。
select 字 ......

magento 在Magento中使用自己写的SQL语句


Magento的Models
和Collection
 很强大,使用它们可以很方便的查询和操作数据库。但是有些场合,因为一些特殊需求或对Magento的了解不够深,可能会需要自己手写SQL语句来查询和操作数据库。以下分别是读写数据库的代码。

// For Read
// fetch read database connection that is used in Mage_Core modul ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号