分页一:
Mysql分页采用limt关键字 select * from t_order limit 5,10; #返回第6-15行数据 select * from t_order limit 5; #返回前5行 select * from t_order limit 0,5; #返回前5行 Mssql 2000分页采用top关键字(20005以上版本也支持关键字rownum) Select top 10 * from t_order where id not in (select id from t_order where id>5 ); //返回第6到15行数据 其中10表示取10记录 5表示从第5条记录开始取 Oracle分页
①采用rownum关键字(三层嵌套) SELECT * FROM( SELECT A.*,ROWNUM num FROM (SELECT * FROM t_order)A WHERE ROWNUM<=15) WHERE num>=5;--返回第5-15行数据 ②采用row_number解析函数进行分页(效率更高) SELECT xx.* FROM( SELECT t.*,row_number() over(ORDER BY o_id)AS num FROM t_order t )xx WHERE num BETWEEN 5 AND 15; --返回第5-15行数据 解析函数能用格式 函数() over(pertion by 字段 order by 字段); Pertion 按照某个字段分区 Order 按照勒个字段排序 用分析函数 一万条后翻最后一页会很慢,使用ROWNUM 一万条之后每翻一页都会慢
分页二:
分页三:
Oracle和Mysql主键、索引及分页的区别
分页四:
一、MySQL
MYSQL中有特定的分页查询语句,该sql语句只能在MySQL中使用
select * from t_customer limit ?,?
该sql语句的意思是,从第几行开始,然后取多少行,MySQL中第一行的下标是0
例如:我要取数据库中的前10行数据,我的sql语句应该这样写:select * from t_customer limit 0,9;
二、Oracle
select * from(select rownum id, t_customer.* from t_customer where rownum <= ? )where id >= ?;
例如:查询第20行到第30行的数据
select * from(select rownum id, t_customer.* from t_customer where rownum <= 30 )where id >= 20;
在做查询记录集的展现时,分页实现是常做的工作了。不同的数据库,分页的实现也不尽相同,这里我们对比Myslq和Oracle来简要说明一下两种常用数据库中的分页实现
1.MySQL中的limit关键字
以模糊查询为例子,limit写到where子句的后面
select * from user where name like '%mm%' limit startrow,readsize;
其中值得推敲的是startrow和readsize也就是开始和读取的记录数
这样查询出来的结果集是从startrow行,读取endsize条记录,实际上查询到的结果集是startrow+1到startrow+readsize的结果,这是操作中我们应该注意的,结果集不包括startrow.
2.Oracle中的rownum关键字
select name,email from (select rownum rn ,name ,email from user where rownum
这样我们就可以得到startrow到endrow结果集,注意结果集合不包括endrow当前行记录,如果条件子句中不是>=startrow,那么查询到的结果集是也不包括startrow当前行记录。
Oracle中主要用到rownum这个伪字段,子查询得到的记录集包括了一个rownum字段,由于Oracle中rownum字段都是从1开始递增的,查询到几条记录就递增到几,所以我们应从后向前截取要查询的记录,并将rownum固定为结果集合的一个字段,然后再使用外层查询就可以以结果集的rownum固定住的字段来利用where子句来操纵记录了。
在使用Oracle或者其它数据库时,使用like 关键字进行模糊查询是大家经常使用的功能,在纯中文环境中使用非常好用,还有一些通配符可以使用,但是在纯英文环境中,会出现大小需要精确匹配的问题,主要原因还是字符串的问题
FL like '%{0}%' and
这里like后是一个字符串,这样必然会有大小敏感的问题。比如如下的大小混编的字段
方案1
使用Oracle系统函数对需要查询的列字符串进行小写转换(大写也行,变量相关部分都是大写转换),如下所示:
select * from logo where lower(bsname) like '%cz%'
当然这样还是不够的需要将代码中变量也转换成相应的小写
String.Format(" select * from logo where lower(bsname) like '%{0}%'", tbfl.ToLower());
该方案的优点:
数据库兼容性好,sql server和mysql都可以按相应的原理来实现
缺点:
sql和代码中添加额外的函数代码,看起来不是这么干净
方案2
使用Oracle 正则表达式语法,完成大小写的模糊匹配 ,具体例子如下
String.Format(" regexp_like(BSNAME,'[:graph:]*{0}[:graph:]*' ,'i') and", tbbs);
看到这里可能有人会觉得写的太浅了,可能觉得“regexp_like”,“[:graph:]*”是什么鬼?
其实以本人实用主义的观点出发完全已经够用了,达到实现like模糊查询的大小写匹配也就够了。
查阅了相关资料,发现oracle的正则表达式竟然对应java的(和c#的命名有些区别),这里
regexp_like是oracle正则匹配的函数
[:graph:]*是匹配任意字符串(0或者n个字符)
“i”参数是忽略字符串大小的意思
具体如果想了解oracle 正则表达式的使用,参考资料我会附上一些外链。这里其实也是我想吐槽的地方,可能也是作为一个实用主义者的一些想法吧,当时我做这个需求的时候,baidu到基本是方案2,但是一些资料基本都是把oracle 正则表达式列出来解释一遍,其实我要的就是一个正则模拟like的功能而已,我想如果作为一个不是精通正则的新手,学习一大堆也未必能用的上,所以我才有把这篇文章分享出来想法,如果有需求就拿去用好了,如果真需要正则,那再深入学习。
该方案的优点:
使用简单,语句干净,考虑的地方少
缺点:
数据库不兼容(别的数据库可能函数不同,需要查阅资料)
SQL模糊查询,使用like比较关键字,加上SQL里的通配符,请参考以下: 1、LIKE'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden)。 2、LIKE'%inger' 将搜索以字母 inger 结尾的所有字符串(如 Ringer、Stringer)。 3、LIKE'%en%' 将搜索在任何位置包含字母 en 的所有字符串(如 Bennet、Green、McBadden)。 4、LIKE'_heryl' 将搜索以字母 heryl 结尾的所有六个字母的名称(如 Cheryl、Sheryl)。 5、LIKE'[CK]ars[eo]n' 将搜索下列字符串:Carsen、Karsen、Carson 和 Karson(如 Carson)。 6、LIKE'[M-Z]inger' 将搜索以字符串 inger 结尾、以从 M 到 Z 的任何单个字母开头的所有名称(如 Ringer)。 7、LIKE'M[^c]%' 将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如MacFeather)。 ------------------------------------------------- 下 面这句查询字符串是我以前写的,根据变量 zipcode_key 在邮政编码表 zipcode 中查询对应的数据,这句是判断变量 zipcode_key 为非数字时的查询语句,用 % 来匹配任意长度的字符串,从表中地址、市、省三列中查询包含关键字的所有数据项,并按省、市、地址排序。这个例子比较简单,只要你理解了方法就可以写出更 复杂的查询语句。 sql = "select * from zipcode where (address like'%" & zipcode_key & "%') or (city like'%" & zipcode_key & "%') or (province like'%" & zipcode_key & "%') order by province,city,address 存储过程中使用模糊查询的例子: SELECT * FROM Questions where QTitle like ' % [ '+ @KeyWord +' ] % ' and IsFinish = @IsFinsih 语句中成对的方括号 是书写格式的关键。