首頁 > 後端開發 > php教程 > php 查询sql server 2008的问题

php 查询sql server 2008的问题

WBOY
發布: 2016-06-23 13:48:39
原創
1152 人瀏覽過

我想要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
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板