首頁 > 軟體

Mysql給普通分頁查詢結果加序號實操

2022-09-24 14:08:25

一、效果展示

1、普通查詢加序號

SELECT t1.NAME,( @i := @i + 1 ) AS '序號' 
FROM t1,( SELECT @i := 0 ) AS itable;

這種情況遇上分頁時會出現每次翻頁都從1開始重新計算,這種情況可以使用分頁偏移量作為開始計算數,解決方案如下:

2、分頁查詢加序號

SELECT ( @i := @i + 1 ) AS '序號' ,t1.NAME
FROM t1,( SELECT @i := 2 ) AS itable
limit 2,5
SELECT ( @i := @i + 1 ) AS '序號' ,t1.NAME
FROM t1,( SELECT @i := #{startSize} ) AS itable
limit #{startSize},#{pageSize};

二、表結構以及資料

CREATE TABLE `t1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `jgid` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

INSERT INTO `avlicy`.`t1`(`id`, `name`, `jgid`) VALUES (1, '二二', 2);
INSERT INTO `avlicy`.`t1`(`id`, `name`, `jgid`) VALUES (2, '李四', 2);
INSERT INTO `avlicy`.`t1`(`id`, `name`, `jgid`) VALUES (4, '七七', 3);
INSERT INTO `avlicy`.`t1`(`id`, `name`, `jgid`) VALUES (5, '小獼猴', 1);
INSERT INTO `avlicy`.`t1`(`id`, `name`, `jgid`) VALUES (6, '小米粥', 1);
INSERT INTO `avlicy`.`t1`(`id`, `name`, `jgid`) VALUES (7, '小哈吧', 1);

三、解釋說明

1、解釋

  • (@i:=@i+1) 也可以寫成 @i:=@i+1 ,加括號是為了視覺上更清晰。它代表的意思是:變數i 加1 賦值給變數i,在定義好一個變數後每次查詢都會給這個變數自增,每次執行查詢語句獲取結果後就不需要這個變數自增了
  • (SELECT @i:=0) AS itable,定義使用者變數i,設定初始值為0,然後將它作為派生表使用,AS定義了表的別名。
  • SET @i=0 。定義使用者變數i,賦初值為0,

2、相關知識點

  • MySQL定義使用者變數的方式:select @變數名 ,上面的SQL語句中,變數的名字是 i
  • 使用者變數賦值:一種是直接用"=“號,另一種是用”:="號。

3、= 和 := 的區別:

使用set命令對使用者變數進行賦值時,兩種方式都可以使用
即:SET @變數名=xxx 或 SET @變數名:=xxx

使用select語句對使用者變數進行賦值時,只能使用":=“方式,因為在select語句中,”="號被看作是比較操作符。即:SELECT @變數名:=xxx

  • ①:使用者變數
  • ②:派生表
  • ③:AS設定別名

到此這篇關於Mysql給普通分頁查詢結果加序號實操的文章就介紹到這了,更多相關Mysql分頁查詢內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com