国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

mysql limit用法之limit分頁詳解

2024-07-24 12:37:50
字體:
供稿:網(wǎng)友

在mysql中l(wèi)imit是計算從X到Y(jié)的偏移記錄,如我們數(shù)據(jù)庫中100條記錄,如果我想取前20條從就可以直接limit 0,20條就可以得到我們要的結(jié)果了,下面我來具體介紹linut用法.

mysql limit語法,代碼如下:

SELECT * FROM table  LIMIT [offset,] rows | rows OFFSET offset

LIMIT 子句可以被用于強制 SELECT 語句返回指定的記錄數(shù),LIMIT 接受一個或兩個數(shù)字參數(shù),參數(shù)必須是一個整數(shù)常量,如果給定兩個參數(shù),第一個參數(shù)指定第一個返回記錄行的偏移量,第二個參數(shù)指定返回記錄行的最大數(shù)目,初始記錄行的偏移量是 0(而不是 1),為了與 PostgreSQL 兼容,MySQL 也支持句法:LIMIT # OFFSET #,代碼如下:

  1. mysql> SELECT * FROM table LIMIT 5,10;  // 檢索記錄行 6-15 
  2. //為了檢索從某一個偏移量到記錄集的結(jié)束所有的記錄行,可以指定第二個參數(shù)為 -1: 
  3. mysql> SELECT * FROM table LIMIT 95,-1; // 檢索記錄行 96-last. 
  4. //如果只給定一個參數(shù),它表示返回最大的記錄行數(shù)目: 
  5. mysql> SELECT * FROM table LIMIT 5;     //檢索前 5 個記錄行 
  6. //換句話說,LIMIT n 等價于 LIMIT 0,n。 

上面的做法在數(shù)據(jù)量小的時間還是很快的,但是各萬張數(shù)據(jù)就不行了,我們可以對limit進行如下優(yōu)化,我現(xiàn)在測試100W數(shù)據(jù)結(jié)果如下:

  1. Select * From yanxue8_visit Where vid >=(Select vid From yanxue8_visit Order By vid limit 10,1  ) limit 10 次運行,時間保持在0.0005-0.0006之間,主要是0.0006 
  2.  
  3. select * from yanxue8_visit limit 10000,10  多次運行,時間保持在0.0187左右 
  4.  
  5. Select * From yanxue8_visit Where vid >=(Select vid From yanxue8_visit Order By vid limit 10000,1  ) limit 10   

多次運行,時間保持在0.0061左右,只有前者的1/3,可以預計offset越大,后者越優(yōu).

結(jié)合與php分頁實例,代碼如下:

  1. <html> 
  2. <head> 
  3. <title> 
  4. ShowData 
  5. </title> 
  6. </head> 
  7. <body> 
  8. <h2>ShowData</h2> 
  9. <?php 
  10.     //連接數(shù)據(jù)庫     
  11.     $page = 1; 
  12.         $db = mysql_connect('127.0.0.1','root','toor'); 
  13.         mysql_select_db('test',$db); 
  14.      
  15.         $pagesize = 3;    //每頁顯示到數(shù)量 
  16.      
  17.     //計算一共有多少記錄,用于計算頁數(shù) 
  18.     $rs = mysql_query("select count(*) from info",$db); 
  19.     $row = @mysql_fetch_array($rs); 
  20.     $numrows = $row[0]; 
  21.     //計算頁數(shù) 
  22.     $pages = intval($numrows / $pagesize); 
  23.     if ($numrows % $pagesize
  24.     { 
  25.         $pages++; 
  26.     } 
  27.     //設(shè)置頁數(shù) 
  28.     if (isset($_GET['page'])) 
  29.     {     
  30.         $page = intval($_GET['page']); 
  31.     } 
  32.     else 
  33.     { 
  34.         $page = 1;        //其他情況,都指向第一頁 
  35.     } 
  36.      
  37.     //計算記錄的偏移量 
  38.     $offset = $pagesize * ($page - 1); 
  39.     //讀取指定記錄 
  40.     $rs = mysql_query("select * from info order by id limit $offset,$pagesize",$db); 
  41.     //把數(shù)據(jù)用表格顯示出來 
  42.     if ($row = @mysql_fetch_array($rs)) 
  43.     { 
  44.         $i = 0; 
  45.         ?> 
  46.         <table border='0' width='80%'
  47.         <tr> 
  48.         <td width='50%'
  49.         <p align='center'>ID</td> 
  50.         <td width='50%'
  51.         <p align='center'>DOC</td> 
  52.         </tr> 
  53.         <?php 
  54.             do
  55.                 $i++; 
  56.         ?> 
  57.         <tr align='center'
  58.         <td width='50%'><?=$row['id']?></td> 
  59.         <td width='50%'><?=$row['doc']?></td> 
  60.         </tr> 
  61.         <?php 
  62.             } 
  63.             //循環(huán)顯示數(shù)據(jù) 
  64.             while ($row = mysql_fetch_array($rs)); 
  65.             echo "</table>"
  66.     } 
  67.     echo "<div align='center'> 共".$pages."頁(".$page."/".$pages.")"
  68.     for ($i = 1;$i < $page;$i++) 
  69.     { 
  70.         echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>"
  71.     }  //Vevb.com 
  72.     echo "[".$page."]"
  73.     for ($i = $page + 1;$i <= $pages;$i++) 
  74.     { 
  75.         echo "<a href='showdata.php?page=".$i."'>[".$i."]</a>"
  76.     } 
  77.     echo "</div>"
  78.     ?> 
  79. </body> 
  80. </html>

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 甘洛县| 巍山| 连州市| 即墨市| 邳州市| 永嘉县| 吉木萨尔县| 涟源市| 安多县| 临泽县| 彝良县| 昌乐县| 靖边县| 随州市| 宁海县| 峨眉山市| 广饶县| 德江县| 海城市| 长寿区| 蒲江县| 金川县| 车致| 喀什市| 平乡县| 布尔津县| 长春市| 留坝县| 德令哈市| 抚顺市| 清河县| 巫山县| 永新县| 孝感市| 梅河口市| 巴东县| 天台县| 西乌珠穆沁旗| 宁夏| 四会市| 洛阳市|