久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

聯(lián)合返回具有限制 postgresql 的不同輸出

Union returning different outputs with limit postgresql(聯(lián)合返回具有限制 postgresql 的不同輸出)
本文介紹了聯(lián)合返回具有限制 postgresql 的不同輸出的處理方法,對大家解決問題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!

問題描述

限時(shí)送ChatGPT賬號(hào)..

我必須根據(jù)難度級(jí)別從我的問題集中提取 12 個(gè)問題.以下是我寫的查詢.

I have to fetch 12 questions from my question set based on the difficulty level. Following is the query I have written.

(SELECT q.question_text, q.option_a, q.option_b, q.option_c, q.option_d,
        q.correct_answer, q.image_link, q.question_type
        FROM questions_bank q
        JOIN sports_type st ON st.id = q.sports_type_id
        JOIN difficulty_level dl ON dl.id = q.difficulty_level_id
        WHERE st.game_type = LOWER('cricket') AND dl.value = 'E'
        ORDER BY random()
        LIMIT 7) 
UNION 
(SELECT q.question_text, q.option_a, q.option_b, q.option_c, q.option_d,
        q.correct_answer, q.image_link, q.question_type
        FROM questions_bank q
        JOIN sports_type st ON st.id = q.sports_type_id
        JOIN difficulty_level dl ON dl.id = q.difficulty_level_id
        WHERE st.game_type = LOWER('cricket') AND dl.value = 'M'
        ORDER BY random()
        LIMIT 4)
UNION 
(SELECT q.question_text, q.option_a, q.option_b, q.option_c, q.option_d, 
        q.correct_answer, q.image_link, q.question_type
        FROM questions_bank q
        JOIN sports_type st ON st.id = q.sports_type_id
        JOIN difficulty_level dl ON dl.id = q.difficulty_level_id
        WHERE st.game_type = LOWER('cricket') AND dl.value = 'H'
        ORDER BY random()
        LIMIT 1);

問題是,每當(dāng)我運(yùn)行這個(gè)查詢時(shí),每次它都會(huì)給我不同數(shù)量的結(jié)果,而不是靜態(tài)的 12.有時(shí)我得到 12,有時(shí) 10,有時(shí) 15.我希望輸出中有 12 行,而不是更少,不多.

The issue is that whenever I run this query, each time it gives me a different number of results instead of the static 12. Sometimes I get 12, sometimes 10, sometimes 15. I expect 12 rows in output, not less, not more.

這個(gè)查詢有什么問題?

推薦答案

使用窗口函數(shù)可以簡化為單個(gè)選擇:

It can be reduced to a single select by using a window function:

select *
from (
    select
        row_number() over (partition by dl.value order by random()) as rn,
        dl.value,
        q.question_text, q.option_a, q.option_b, q.option_c, q.option_d,
        q.correct_answer, q.image_link, q.question_type
    from
        questions_bank q
        inner join
        sports_type st on st.id = q.sports_type_id
        inner join
        difficulty_level dl on dl.id = q.difficulty_level_id
    where st.game_type = lower('cricket') and dl.value in ('E','M','H')
) s
where 
    value = 'E' and rn <= 7 or
    value = 'M' and rn <= 4 or
    value = 'H' and rn = 1

這篇關(guān)于聯(lián)合返回具有限制 postgresql 的不同輸出的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!

相關(guān)文檔推薦

Typeorm Does not return all data(Typeorm 不返回所有數(shù)據(jù))
MySQL return extra records when using a long type number to filter varchar type(MySQL在使用長類型數(shù)字過濾varchar類型時(shí)返回額外記錄)
MySQL Error #1071 - Specified key was too long; max key length is 767 bytes(MySQL 錯(cuò)誤 #1071 - 指定的鍵太長;最大密鑰長度為 767 字節(jié))
MySQL command-line table column width with utf8(MySQL命令行表列寬與utf8)
Python unicode encoding issue(Python unicode 編碼問題)
Create a MySQL stored function with a dynamic number of arguments(創(chuàng)建一個(gè)帶有動(dòng)態(tài)參數(shù)數(shù)量的 MySQL 存儲(chǔ)函數(shù))
主站蜘蛛池模板: 日韩欧美大片在线观看 | 四虎在线观看 | 久久99精品久久久久久国产越南 | 国产一区二区三区视频在线观看 | 成人在线一区二区 | 日日日干干干 | 成人免费区一区二区三区 | 高清久久久 | 久久国产精品久久久久久 | 日韩国产免费观看 | 精品产国自在拍 | 亚洲欧美视频 | 国产激情网站 | 国产91丝袜在线播放 | 国产精品久久网 | 亚洲欧美日韩系列 | 91精品久久久 | av影音| 久久精品无码一区二区三区 | zzzwww在线看片免费 | 九九热免费观看 | 久久国产区 | 日韩一 | 九九热免费在线观看 | 中文字字幕在线中文乱码范文 | 国产h视频 | 精品一区二区电影 | 在线观看日韩av | 久久精品一区 | 自拍偷拍第一页 | 国产91久久久久蜜臀青青天草二 | 国产精品99久久久久久久久 | 中文字幕三区 | 在线一区| 欧美一区二区三区视频 | 欧美成人精品激情在线观看 | 国产久 | 野狼在线社区2017入口 | 国产精品久久久久久久久免费桃花 | 久久成人精品视频 | 91资源在线播放 |