一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php mssql 分頁SQL語句優化 持續影響

復制代碼 代碼如下:
<?php
/**
* @Filename :page.sql.class.php
* @CreatTime :2009-01-06
* @Descrition :此類為SQL語句處理類。
* @UpdateTime-1 :null
* @Version :jswweb1.0.0
* @Author :fkedwgwy
* @Dome :
$sql//SQL語句
$allcount//總記錄數
$pagesize//頁面顯示記錄條數
$page//當前頁
$sqlc= new sqlpage($sql,$allcount,$pagesize,$page);
$sql=$sqlc->getsql();
優化后的語句:
SELECT * FROM (SELECT TOP 10 * FROM (SELECT TOP 270 Lsh,Ztm,Dyzrsm,Dyzzfs,Cbsm,Cbny,Ssh,Fbsl,jcsl from ts_gcb where Ssh like 'C%' order by Lsh asc) AS inner_tbl ORDER BY Lsh DESC) AS outer_tbl ORDER BY Lsh asc
*/
class sqlpage{
function sqlpage($sql,$allcount,$pagesize,$page){
$this->sql= $sql;//查詢語名
$this->allcount= intval($allcount);//總記錄數
$this->pagesize= intval($pagesize);//頁面大小(顯示記錄數)
$this->page= intval($page);//當前頁
$this->getpage();
$this->gettop();
}
function getpage(){ //獲取當前頁
$this->allpage=ceil( $this->allcount/$this->pagesize);//去當前小數的最大整數
if ($this->page=="" or $this->page>$this->allpage or $this->page<0 or $this->page==0){
$this->page2=1;
}else{
$this->page2=intval($this->page);//將頁碼轉換為數字
}
}
function gettop(){ //獲取子查詢2的TOP大小
if ($this->page2<$this->allpage){
$this->top2=$this->pagesize;
}else{
$this->top2=$this->allcount-$this->pagesize*($this->allpage-1);
}
}
/* function getsql(){//獲取SQL語句
$this->s=preg_replace("/select/i","",$this->sql);
$this->top1=$this->pagesize*$this->page2;
$this->sql1="SELECT TOP $this->top1 $this->s";
if (strpos($this->sql,"asc")){//升序
$this->sql_e="select * from ( select TOP $this->top2 * FROM ( $this->sql1 ) as aSysTable ORDER BY $this->order DESC ) as bSysTable ORDER BY $this->order ASC";
}else
//$this->sql_e="select * from ( select TOP $this->top2 * FROM ( $this->sql1 ) as aSysTable ORDER BY $this->order DESC ) as bSysTable ORDER BY $this->order ASC";
if (strpos($this->sql,"desc")){//降序
$this->sql_e="select * from ( select TOP $this->top2 * FROM ( $this->sql1 ) as aSysTable ORDER BY $this->order asc ) as bSysTable ORDER BY $this->order desc";
}else{//不處理排序的情況
$this->sql_e="select * from ( select TOP $this->top2 * FROM ( $this->sql1 ) as aSysTable ORDER BY $this->order DESC ) as bSysTable ORDER BY $this->order ASC";
}
// echo $this->sql_e;
return $this->sql_e;
}*/
function getsql()
{
$sql=$this->sql;
$this->top1=$this->pagesize*$this->page2;
$orderby = stristr($sql, 'ORDER BY');
if ($orderby !== false) {
$sort = (stripos($orderby, ' desc') !== false) ? 'desc' : 'asc';
$order = str_ireplace('ORDER BY', '', $orderby);
$order = trim(preg_replace('//bASC/b|/bDESC/b/i', '', $order));
}
$sql = preg_replace('/^SELECT/s/i', 'SELECT TOP ' . ($this->top1) . ' ', $sql);
$sql = 'SELECT * FROM (SELECT TOP ' . $this->top2 . ' * FROM (' . $sql . ') AS inner_tbl';
if ($orderby !== false) {
$sql .= ' ORDER BY ' . $order . ' ';
$sql .= (stripos($sort, 'asc') !== false) ? 'DESC' : 'ASC';
}
$sql .= ') AS outer_tbl';
if ($orderby !== false) {
$sql .= ' ORDER BY ' . $order . ' ' . $sort;
}
echo $sql;
return $sql;
}
}
?>

php技術php mssql 分頁SQL語句優化 持續影響,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美一区二区久久精品 | 四虎在线观看免费视频 | 五月婷婷啪 | 伊人热人久久中文字幕 | 日本在线视频免费观看 | 天天色成人| 亚洲精品国产综合久久一线 | 国产成人亚洲日本精品 | 免费啪视频观在线视频在线 | 久久午夜精品2区 | 最新福利小视频在线播放 | 日韩一区二区久久久久久 | 丝袜二区 | 国产午夜免费视频片夜色 | 色哟哟在线观看视频高清大全 | 91精品国产综合久久青草 | 午夜国产高清精品一区免费 | 黄色影院在线观看视频 | 国产精品视频一区二区猎奇 | 日韩精品高清自在线 | 亚洲欧美一级久久精品 | 久久夜色精品国产噜噜亚洲a | 亚洲六月丁香六月婷婷花 | 久久久久久久91精品免费观看 | 欧美日韩亚洲一区二区三区 | 丁香婷婷基地 | 伊人久久大香线蕉综合爱婷婷 | 男人靠女人视频无遮挡大全 | 69女poren60| 日韩视频免费一区二区三区 | 999影院成 人在线影院 | 久久精品2 | 91视频最新网址 | 色一涩| 国内外成人免费在线视频 | 国产免费黄色大片 | 国产视频网 | 国产成人一区二区视频在线观看 | 亚洲国产精久久久久久久 | 色国产精品 | 精品综合久久久久久97超人该 |