<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
        當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

        MySQL實(shí)現(xiàn)Oracle或者PostgreSQL的row_numberover這樣的排名語(yǔ)法_MySQL

        來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 18:51:46
        文檔

        MySQL實(shí)現(xiàn)Oracle或者PostgreSQL的row_numberover這樣的排名語(yǔ)法_MySQL

        MySQL實(shí)現(xiàn)Oracle或者PostgreSQL的row_numberover這樣的排名語(yǔ)法_MySQL:bitsCN.com PostgreSQL 和Oracle 都提供了 row_number() over() 這樣的語(yǔ)句來(lái)進(jìn)行對(duì)應(yīng)的字段排名, 很是方便。 MySQL卻沒(méi)有提供這樣的語(yǔ)法。Table ytt.t1 Column | Type | Modifiers --------+-----------------
        推薦度:
        導(dǎo)讀MySQL實(shí)現(xiàn)Oracle或者PostgreSQL的row_numberover這樣的排名語(yǔ)法_MySQL:bitsCN.com PostgreSQL 和Oracle 都提供了 row_number() over() 這樣的語(yǔ)句來(lái)進(jìn)行對(duì)應(yīng)的字段排名, 很是方便。 MySQL卻沒(méi)有提供這樣的語(yǔ)法。Table ytt.t1 Column | Type | Modifiers --------+-----------------

        bitsCN.com PostgreSQL 和Oracle 都提供了 row_number() over() 這樣的語(yǔ)句來(lái)進(jìn)行對(duì)應(yīng)的字段排名, 很是方便。 MySQL卻沒(méi)有提供這樣的語(yǔ)法。
        Table "ytt.t1" Column | Type | Modifiers --------+-----------------------+----------- i_name | character varying(10) | not null rank | integer | not null
        t_girl=# select * from t1 order by i_name; i_name | rank ---------+------ Charlie | 12 Charlie | 12 Charlie | 13 Charlie | 10 Charlie | 11 Lily | 6 Lily | 7 Lily | 7 Lily | 6 Lily | 5 Lily | 7 Lily | 4 Lucy | 1 Lucy | 2 Lucy | 2 Ytt | 14 Ytt | 15 Ytt | 14 Ytt | 14 Ytt | 15 (20 rows)
        t_girl=# select i_name,rank, row_number() over(partition by i_name order by rank desc) as rank_number from t1; i_name | rank | rank_number ---------+------+------------- Charlie | 13 | 1 Charlie | 12 | 2 Charlie | 12 | 3 Charlie | 11 | 4 Charlie | 10 | 5 Lily | 7 | 1 Lily | 7 | 2 Lily | 7 | 3 Lily | 6 | 4 Lily | 6 | 5 Lily | 5 | 6 Lily | 4 | 7 Lucy | 2 | 1 Lucy | 2 | 2 Lucy | 1 | 3 Ytt | 15 | 1 Ytt | 15 | 2 Ytt | 14 | 3 Ytt | 14 | 4 Ytt | 14 | 5 (20 rows)


        t_girl=# select i_name,rank, row_number() over(partition by i_name ) as rank_number from t1; i_name | rank | rank_number ---------+------+------------- Charlie	 | 12 | 1 Charlie	| 12 | 2 Charlie	| 13 | 3 Charlie	| 10 | 4 Charlie	| 11 | 5 Lily	| 6 | 1 Lily	| 7 | 2 Lily	| 7 | 3 Lily	| 6 | 4 Lily	| 5 | 5 Lily	| 7 | 6 Lily	| 4 | 7 Lucy	| 1 | 1 Lucy	| 2 | 2 Lucy	| 2 | 3 Ytt	| 14 | 1 Ytt	| 15 | 2 Ytt	| 14 | 3 Ytt	| 14 | 4 Ytt	| 15 | 5(20 rows)



        t_girl=# select i_name,rank, row_number() over() as rank_number from t1; i_name | rank | rank_number ---------+------+------------- Lily	 | 7 | 1 Lucy	| 2 | 2 Ytt	| 14 | 3 Ytt	| 14 | 4 Charlie	| 12 | 5 Charlie	| 13 | 6 Lily	| 7 | 7 Lily	| 4 | 8 Ytt	| 14 | 9 Lily	| 6 | 10 Lucy	| 1 | 11 Lily	| 7 | 12 Ytt	| 15 | 13 Lily	| 6 | 14 Charlie	| 11 | 15 Charlie	| 12 | 16 Lucy	| 2 | 17 Charlie	| 10 | 18 Lily	| 5 | 19 Ytt	| 15 | 20(20 rows)


        DELIMITER $$ USE `t_girl`$$ DROP PROCEDURE IF EXISTS `sp_rownumber`$$ CREATE PROCEDURE `sp_rownumber`( IN f_table_name VARCHAR(64), IN f_column_partitionby VARCHAR(64), IN f_column_orderby VARCHAR(64), IN f_is_asc CHAR(4) ) BEGIN -- Created by ytt at 2014/1/10 -- Do a row_number() over() DECLARE i INT; -- Create a temporary table to save result. DROP TABLE IF EXISTS tmp_rownum; SET @stmt = CONCAT('create temporary table tmp_rownum select *,''rownum'' from ',f_table_name,' where 1 = 0'); PREPARE s1 FROM @stmt; EXECUTE s1; SET i = 0; SET @j = 0; SET @v_column_paritionby = ''; -- Check whether parition column is null or not. IF (f_column_partitionby = '' OR f_column_partitionby IS NULL) THEN -- No additional parition column. SET @stmt = CONCAT('insert into tmp_rownum select *,@j:= @j+1 as rownum from ', f_table_name); PREPARE s1 FROM @stmt; EXECUTE s1; ELSE -- Give partition column. SET @stmt = CONCAT('select count(*) from (select count(*) from ',f_table_name,' group by ', f_column_partitionby,') as a into @cnt'); PREPARE s1 FROM @stmt; EXECUTE s1; WHILE i < @cnt DO -- Get the partition value one by one. SET @stmt = CONCAT('select ',f_column_partitionby,' from ',f_table_name,' group by ',f_column_partitionby,' limit ',i,',1 into @v_column_partitionby'); PREPARE s1 FROM @stmt; EXECUTE s1; -- Check whether sort is needed. IF f_column_orderby = '' OR f_column_orderby IS NULL THEN SET @stmt = CONCAT('insert into tmp_rownum select *,@j:= @j+1 as rownum from ', f_table_name,' where ',f_column_partitionby,' = ''',@v_column_partitionby,''''); ELSE SET @stmt = CONCAT('insert into tmp_rownum select *,@j:= @j+1 as rownum from ', f_table_name,' where ',f_column_partitionby,' = ''',@v_column_partitionby,''' order by ',f_column_orderby,' ',f_is_asc); END IF; SET @j = 0; PREPARE s1 FROM @stmt; EXECUTE s1; SET i = i + 1; END WHILE; END IF; -- Reset all session variables. SET @j = NULL; SET @v_column_paritionby = NULL; SET @cnt = NULL; SELECT * FROM tmp_rownum; END$$ DELIMITER ;


        CALL sp_rownumber('t1','i_name','rank','desc');query resulti_name	rank	rownumCharlie	13	1Charlie	12	2Charlie	12	3Charlie	11	4Charlie	10	5Lily	7	1Lily	7	2Lily	7	3Lily	6	4Lily	6	5Lily	5	6Lily	4	7Lucy	2	1Lucy	2	2Lucy	1	3Ytt	15	1Ytt	15	2Ytt	14	3Ytt	14	4Ytt	14	5

        第二種,

        CALL sp_rownumber('t1','i_name',NULL,NULL);query resulti_name	rank	rownumCharlie	12	1Charlie	13	2Charlie	11	3Charlie	12	4Charlie	10	5Lily	7	1Lily	7	2Lily	4	3Lily	6	4Lily	7	5Lily	6	6Lily	5	7Lucy	2	1Lucy	1	2Lucy	2	3Ytt	14	1Ytt	14	2Ytt	14	3Ytt	15	4Ytt	15	5

        第三種,

        CALL sp_rownumber('t1',NULL,NULL,NULL);query resulti_name	rank	rownumLily	7	1Lucy	2	2Ytt	14	3Ytt	14	4Charlie	12	5Charlie	13	6Lily	7	7Lily	4	8Ytt	14	9Lily	6	10Lucy	1	11Lily	7	12Ytt	15	13Lily	6	14Charlie	11	15Charlie	12	16Lucy	2	17Charlie	10	18Lily	5	19Ytt	15	20


        bitsCN.com

        聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        MySQL實(shí)現(xiàn)Oracle或者PostgreSQL的row_numberover這樣的排名語(yǔ)法_MySQL

        MySQL實(shí)現(xiàn)Oracle或者PostgreSQL的row_numberover這樣的排名語(yǔ)法_MySQL:bitsCN.com PostgreSQL 和Oracle 都提供了 row_number() over() 這樣的語(yǔ)句來(lái)進(jìn)行對(duì)應(yīng)的字段排名, 很是方便。 MySQL卻沒(méi)有提供這樣的語(yǔ)法。Table ytt.t1 Column | Type | Modifiers --------+-----------------
        推薦度:
        標(biāo)簽: mysql oracle 這樣的
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 日韩免费观看的一级毛片| 色婷婷7777免费视频在线观看| 四虎永久免费地址在线观看| 亚洲一卡一卡二新区无人区| 九九精品免费视频| 亚洲色无码国产精品网站可下载| 91免费资源网站入口| 亚洲一卡2卡3卡4卡5卡6卡| 成人免费在线观看网站| 亚洲AV无码专区在线厂| 免费欧洲美女牲交视频| 又硬又粗又长又爽免费看| 国产偷国产偷亚洲清高动态图| 国产精品成人啪精品视频免费| 亚洲精品无码午夜福利中文字幕| 免费视频一区二区| 亚洲欧洲国产视频| 在线免费观看一级片| 一级**爱片免费视频| 亚洲av永久无码精品网站| 2020久久精品国产免费| 免费播放美女一级毛片| 亚洲人成亚洲人成在线观看 | 亚洲中文字幕不卡无码| 免费网站看av片| 亚洲日日做天天做日日谢| 免费a级毛片在线观看| 你懂的在线免费观看| 久久亚洲日韩看片无码| 黄网址在线永久免费观看 | 男女一边桶一边摸一边脱视频免费 | 在线看无码的免费网站| 亚洲人成人伊人成综合网无码| 国产91在线免费| 无码人妻久久一区二区三区免费| 亚洲AV无码国产精品色| 亚洲午夜精品第一区二区8050| 67194成手机免费观看| 国产精品亚洲专一区二区三区| 亚洲精品成人片在线播放 | 亚洲AV无码成H人在线观看 |