❶ 如何用sql语句 实现分页查询
适用于 SQL Server 2000/2005
SELECT TOP 页大小 *
FROM table1
WHERE id NOT IN
SELECT TOP 页大小*(页数-1) id FROM table1 ORDER BY id
❷ mysql数据库分页
可以使用TOP分页啊
什么数据库都可以用的
例如:
select
top
5
*
from
a
where
a.id
not
in
(select
top
(5
*
1) id
from
b)
5
一页要获取的条数
1
是页数
1代表的是第二页
❸ MySql中查询语句实现分页功能
pageNow代表当前页面,第一页。
❹ SQL语句分页查询,一页面多少数据合适
2万条。
在SQLServer中通过SQL语句实现分页查询,在SQLServer中通过SQL语句实现分页后插入数据2万条,用更多的数据测试会明显一些。微软的SQLSERVER提供了两种索引:聚集索引,也称聚类索引、簇集索引和非聚集索引,也称非聚类索引、非簇集索引。
建立一个web应用,分页浏览功能必不可少。这个问题是数据库处理中十分常见的问题。经典的数据分页方法是:ADO纪录集分页法,也就是利用ADO自带的分页功能(利用游标)来实现分页。但这种分页方法仅适用于较小数据量的情形,因为游标本身有缺点:游标是存放在内存中,很费内存。游标一建立,就将相关的记录锁住,直到取消游标。游标提供了对特定集合中逐行扫描的手段,一般使用游标来逐行遍历数据,根据取出数据条件的不同进行不同的操作。而对于多表和大表中定义的游标(大的数据集合)循环很容易使程序进入一个漫长的等待甚至死机。更重要的是,对于非常大的数据模型而言,分页检索时,如果按照传统的每次都加载整个数据源的方法是非常浪费资源的。现在流行的分页方法一般是检索页面大小的块区的数据,而非检索所有的数据,然后单步执行当前行。最早较好地实现这种根据页面大小和页码来提取数据的方法大概就是“俄罗斯存储过程”。这个存储过程用了游标,由于游标的局限性,所以这个方法并没有得到大家的普遍认可,后来,网上有人改造了此存储过程,实现了分页储存。
❺ MySQL分页的sql语言怎么写
1、首先我们建立一个表表的数据,这个表里有25条数据,id从1到25。(下图是部分截图)
❻ mysql 内嵌sql 如何分页
直接在最外层分页就好了
SELECT
COUNT(1) AS NO,
base_id,
ycpersonal_id,
yc_cert_id,
ouid,
udepartmentID,
de_name,
cert_level,
cert_level_name,
cert_profession,
cert_profession_name,
cert_binding,
cert_binding_name,
three_classes,
three_classes_name
FROM
(
SELECT
cb.id AS base_id,
ct.id AS ycpersonal_id,
ce.id AS yc_cert_id,
cb.ouid,
cb.udepartmentID,
de.name AS de_name,
ce.cert_level,
gc.name AS cert_level_name,
ce.cert_profession,
gp.name AS cert_profession_name,
ce.cert_binding,
gb.name AS cert_binding_name,
ct.three_classes,
ge.name AS three_classes_name
FROM
`my_conm_base` AS cb
LEFT JOIN my_conm_ycpersonnel AS ct
ON cb.id = ct.conmid
LEFT JOIN my_conm_ycpersonnel_cert AS ce
ON ce.personnelid = ct.id
LEFT JOIN my_category AS gc
ON gc.id = ce.cert_level
LEFT JOIN my_category AS gp
ON gp.id = ce.cert_profession
LEFT JOIN my_category AS gb
ON gb.id = ce.cert_binding
LEFT JOIN my_category AS ge
ON ge.id = ct.three_classes
LEFT JOIN my_department AS de
ON de.id = cb.udepartmentID
WHERE cb.state <> 18
AND cb.udepartmentid IN (10001)
AND cb.stype = 961
AND ce.id > 0
GROUP BY ce.personnelid
ORDER BY cb.id,
ce.cert_level DESC
) AS LIST
GROUP BY cert_level,
cert_profession,
cert_binding,
three_classes
ORDER BY cert_level limit 0,10
❼ Oracle, SQL Server, My SQL如何实现数据分页查询语句
Oracle, SQL Server 和MySQL的分页SQL语句如下:Oracle:方法一:SELECT * FROM(SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A WHERE ROWNUM <= 40)WHERE RN = 21;方法二:SELECT * FROM(SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A)WHERE RN between 21 and 40 公认第二种方法效率没有第一种高。原因是第二种要把子查询执行完,而第一种方法子查询执行到Rownum=40后就结束了。MySQL: SELECT * FROM TABLE_NAME LIMIT 10, 20 表示从第11条数据开始取20条数据返回,limit后的2个参数含义为:起点和步长,即从那条数据开始,取多少条数据,再如取前20条数据:SELECT * FROM TABLE_NAME LIMIT 0, 20 SQL Server2000: SELECT TOP @pagesize * FROM TABLE_NAME WHERE id not in (SELECT TOP @pagesize*(@page-1) id FROM TABLE_NAME ORDER BY id) ORDER BY id
❽ Mysql 的模糊分页查询,SQL语句怎么写啊大神吗,求救!!!
$page=$_GET['page'];
$pagesize=20;
$pages=($page-1)*$pagesize+1;
$sql='select*fromtablenamewheretitlelike"%张三%"limit'.$pages.','.$pagesize;
❾ Mysql 数据库怎么实现分页,要说的通俗一点儿
一个不带limit 一个带limit。以php+mysql为例首先,连接数据库,写一条sql语句把你要查询的信息总量查找出来sql = select count(*) from tb,$all_page ;设定每页显示条数, $display 。然后,当前页为$page ;在写一句sql = select * from tb limit $dispaly*($page - 1),$display;最后,在页面显示分页信息把当前页传回给分页处理页,一定要把相关的条件一起传回去,get 方式传值,否则查询条件改变查询信息就不正确。 网上有好多封装好的分页类。我也有一个很好用的分页类,如果请我吃肉就发给你一份哈。。\(^o^)/~ 追问: 这个$all_page用在哪儿,怎么将当前页传回给分页处理页。显示的时候那些“首页”“上一页”“下一页”“末页”是链接吗、链到什么地方,还是别的什么 回答: $all_page是查询总数,总是页数等于查询总数除以每页显示的信息。$num_page = ceil($all_page/$display); 用get方式把当前页传给分页处理页,就是<a href = "连接到本页或着不写也就是当前页?page=当前页码"></a>标签 别的我也想不起来,让我自己写分页,我只会最简单的那种,一般我都是调用一个现成的分页类。只需传个参数就Ok,连样式都不用写的。。。
❿ mysql如何做分页查询
直接用limit start, count分页语句, 也是我程序中用的方法:
select * from proct limit start, count
当起始页较小时,查询没有性能问题,我们分别看下从10, 100, 1000, 10000开始分页的执行时间(每页取20条), 如下:
select * from proct limit 10, 20 0.016秒
select * from proct limit 100, 20 0.016秒
select * from proct limit 1000, 20 0.047秒
select * from proct limit 10000, 20 0.094秒
我们已经看出随着起始记录的增加,时间也随着增大, 这说明分页语句limit跟起始页码是有很大关系的,那么我们把起始记录改为40w看下(也就是记录的一般左右) select * from proct limit 400000, 20 3.229秒
再看我们取最后一页记录的时间
select * from proct limit 866613, 20 37.44秒
难怪搜索引擎抓取我们页面的时候经常会报超时,像这种分页最大的页码页显然这种时
间是无法忍受的。
从中我们也能总结出两件事情:
1)limit语句的查询时间与起始记录的位置成正比
2)mysql的limit语句是很方便,但是对记录很多的表并不适合直接使用。