首页 > 后端开发 > php教程 > php 查询sql server 2008的问题

php 查询sql server 2008的问题

WBOY
发布: 2016-06-23 13:48:39
原创
1159 人浏览过

我想要php分页从sql server 2008获取数据,

1.   mysql 可以 limit n,m  ,sql server没有
2.   要分页获取 union  后的数据, 网上看到有用rownum 和 top 的,请问怎么与union结合实现呢


我的结果集类似于

(select A,B,C,D from t1) union (select '100' as A ,B,C,D  from t2)  union (select A,B,C,D from t3)
登录后复制


想限制每次返回结果集的 哪一条到哪一条


回复讨论(解决方案)

这样写:

$sql = '你的sql查询指令';$start = 1; //起始偏移$pagesize = 20; //每页行数$sqls =<<< SQLSELECT * FROM (SELECT A.*, ROWNUM RN FROM ($sql) A WHERE ROWNUM < $start+$pagesize)WHERE RN >= $startSQL;
登录后复制
$sqls 就是最终执行的查询语句

理解了,原来我的问题在于 不知道给union 的结果取个别名,谢谢版主大人~~

最后结合百度 我是这样写的

SELECT * FROM (     SELECT  * , ROW_NUMBER() OVER (ORDER BY A DESC) AS rn          FROM  ($sql)  AS s1)AS s2  where rn between $from and $to
登录后复制

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板