您好,登錄后才能下訂單哦!
這篇文章主要介紹“MySQL怎么實(shí)現(xiàn)自動(dòng)為查詢數(shù)據(jù)結(jié)果加序號(hào)”,在日常操作中,相信很多人在MySQL怎么實(shí)現(xiàn)自動(dòng)為查詢數(shù)據(jù)結(jié)果加序號(hào)問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”MySQL怎么實(shí)現(xiàn)自動(dòng)為查詢數(shù)據(jù)結(jié)果加序號(hào)”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
DROP TABLE IF EXISTS tb_score; CREATE TABLE tb_score( id INT(11) NOT NULL auto_increment, userid VARCHAR(20) NOT NULL COMMENT '用戶id', subject VARCHAR(20) COMMENT '科目', score DOUBLE COMMENT '成績(jī)', PRIMARY KEY(id) )ENGINE = INNODB DEFAULT CHARSET = utf8; INSERT INTO tb_score(userid,subject,score) VALUES ('001','語文',90); INSERT INTO tb_score(userid,subject,score) VALUES ('001','數(shù)學(xué)',92); INSERT INTO tb_score(userid,subject,score) VALUES ('001','英語',80); INSERT INTO tb_score(userid,subject,score) VALUES ('002','語文',88); INSERT INTO tb_score(userid,subject,score) VALUES ('002','數(shù)學(xué)',90); INSERT INTO tb_score(userid,subject,score) VALUES ('002','英語',75.5); INSERT INTO tb_score(userid,subject,score) VALUES ('003','語文',70); INSERT INTO tb_score(userid,subject,score) VALUES ('003','數(shù)學(xué)',85); INSERT INTO tb_score(userid,subject,score) VALUES ('003','英語',90); INSERT INTO tb_score(userid,subject,score) VALUES ('003','政治',82);
一種普遍的解決方法是:通過定義用戶變量生成序號(hào)
舉例:查詢表中的數(shù)據(jù)并加上序號(hào),對(duì)應(yīng)的SQL為:
SELECT id,userid,subject,score, (@i :=@i + 1) AS '序號(hào)' FROM tb_score, (SELECT @i := 0) AS itable;
+----+--------+---------+-------+--------+ | id | userid | subject | score | 序號(hào) | +----+--------+---------+-------+--------+ | 1 | 001 | 語文 | 90 | 1 | | 2 | 001 | 數(shù)學(xué) | 92 | 2 | | 3 | 001 | 英語 | 80 | 3 | | 4 | 002 | 語文 | 88 | 4 | | 5 | 002 | 數(shù)學(xué) | 90 | 5 | | 6 | 002 | 英語 | 75.5 | 6 | | 7 | 003 | 語文 | 70 | 7 | | 8 | 003 | 數(shù)學(xué) | 85 | 8 | | 9 | 003 | 英語 | 90 | 9 | | 10 | 003 | 政治 | 82 | 10 | +----+--------+---------+-------+--------+ 10 rows in set (0.00 sec)
SELECT *, (@i :=@i + 1) AS '序號(hào)' FROM tb_score;
+----+--------+---------+-------+--------+ | id | userid | subject | score | 序號(hào) | +----+--------+---------+-------+--------+ | 1 | 001 | 語文 | 90 | 11 | | 2 | 001 | 數(shù)學(xué) | 92 | 12 | | 3 | 001 | 英語 | 80 | 13 | | 4 | 002 | 語文 | 88 | 14 | | 5 | 002 | 數(shù)學(xué) | 90 | 15 | | 6 | 002 | 英語 | 75.5 | 16 | | 7 | 003 | 語文 | 70 | 17 | | 8 | 003 | 數(shù)學(xué) | 85 | 18 | | 9 | 003 | 英語 | 90 | 19 | | 10 | 003 | 政治 | 82 | 20 | +----+--------+---------+-------+--------+ 10 rows in set (0.00 sec)
或者
SET @i=0; SELECT id,userid,subject,score,@i:=@i+1 AS '序號(hào)' FROM tb_score;
+----+--------+---------+-------+--------+ | id | userid | subject | score | 序號(hào) | +----+--------+---------+-------+--------+ | 1 | 001 | 語文 | 90 | 1 | | 2 | 001 | 數(shù)學(xué) | 92 | 2 | | 3 | 001 | 英語 | 80 | 3 | | 4 | 002 | 語文 | 88 | 4 | | 5 | 002 | 數(shù)學(xué) | 90 | 5 | | 6 | 002 | 英語 | 75.5 | 6 | | 7 | 003 | 語文 | 70 | 7 | | 8 | 003 | 數(shù)學(xué) | 85 | 8 | | 9 | 003 | 英語 | 90 | 9 | | 10 | 003 | 政治 | 82 | 10 | +----+--------+---------+-------+--------+ 10 rows in set (0.00 sec)
1、(@i:=@i+1)
也可以寫成 @i:=@i+1
,加括號(hào)是為了視覺上更清晰。
它代表的意思是:變量 i
加 1
賦值給變量 i
,在定義好一個(gè)變量后每次查詢都會(huì)給這個(gè)變量自增,每次執(zhí)行查詢語句獲取結(jié)果后就不需要這個(gè)變量自增了。
2、(SELECT @i:=0) AS itable
,定義用戶變量 i
,設(shè)置初始值為 0
,然后將它作為派生表使用,AS 定義了表的別名。
3、SET @i=0
。定義用戶變量 i
,賦初值為 0
。
1、MySQL定義用戶變量的方式:
select @變量名
,上面的SQL語句中,變量的名字是 i
。
2、用戶變量賦值:一種是直接用 "="
號(hào),另一種是用 ":="
號(hào)。
=
和 :=
的區(qū)別
使用 set 命令對(duì)用戶變量進(jìn)行賦值時(shí),兩種方式都可以使用,即:SET @變量名=xxx
或 SET @變量名:=xxx
使用 select 語句對(duì)用戶變量進(jìn)行賦值時(shí),只能使用 ":=“
方式,因?yàn)樵?select 語句中,”="
號(hào)被看作是比較操作符。
即:SELECT @變量名:=xxx
:
①:用戶變量
②:派生表
③:AS設(shè)置別名
到此,關(guān)于“MySQL怎么實(shí)現(xiàn)自動(dòng)為查詢數(shù)據(jù)結(jié)果加序號(hào)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。