東坡下載:內(nèi)容最豐富最安全的下載站!

首頁(yè)編程開(kāi)發(fā)數(shù)據(jù)庫(kù) → sql指定條件排序的方法

sql指定條件排序的方法

相關(guān)文章發(fā)表評(píng)論 來(lái)源:本站原創(chuàng)時(shí)間:2014/3/4 21:46:02字體大小:A-A+

更多

作者:admin點(diǎn)擊:1203次評(píng)論:0次標(biāo)簽: sql

sql server 2012
類(lèi)型:國(guó)外軟件大小:4.39G語(yǔ)言:中文時(shí)間:16-03-21評(píng)分:2.8
sql server 2005 sp4補(bǔ)丁文件
類(lèi)型:國(guó)外軟件大。391.1M語(yǔ)言:中文時(shí)間:16-03-21評(píng)分:10.0

今天在做網(wǎng)站的專(zhuān)題的時(shí)候,因?yàn)槲恼绿伲俏矣窒胝{(diào)用指定一個(gè)條件的數(shù)據(jù),但是這個(gè)條件的數(shù)據(jù)又不是很多,所以我就想將滿(mǎn)足條件的數(shù)據(jù)顯示在最前面,然后不滿(mǎn)足條件的數(shù)據(jù)放在后面隨機(jī)顯示。

上圖可以看出,我將天天愛(ài)消除的所有記錄放在最前面,非天天愛(ài)消除的記錄放在后面,并且隨機(jī)顯示。

查了很多資料,也在mssql權(quán)威的群里問(wèn)了很多人,可以是時(shí)間關(guān)系回復(fù)的并不多,也沒(méi)有具體的方案。

看來(lái)一個(gè)小論壇啟發(fā)了我,我上面的語(yǔ)句如下:

SELECT TOP 10 *   FROM 查詢(xún)的表名  ORDER BY CASE WHEN (Title LIKE '%天天愛(ài)消除%') THEN 0 ELSE 1 END, NEWID()


Case具有兩種格式。簡(jiǎn)單Case函數(shù)和Case搜索函數(shù)。

--簡(jiǎn)單Case函數(shù)CASE sexWHEN '1' THEN '男'WHEN '2' THEN '女'ELSE '其他' END--Case搜索函數(shù)CASE WHEN sex = '1' THEN '男'WHEN sex = '2' THEN '女'ELSE '其他' END


這兩種方式,可以實(shí)現(xiàn)相同的功能。簡(jiǎn)單Case函數(shù)的寫(xiě)法相對(duì)比較簡(jiǎn)潔,但是和Case搜索函數(shù)相比,功能方面會(huì)有些限制,比如寫(xiě)判斷式。 
還有一個(gè)需要注意的問(wèn)題,Case函數(shù)只返回第一個(gè)符合條件的值,剩下的Case部分將會(huì)被自動(dòng)忽略。 

--比如說(shuō),下面這段SQL,你永遠(yuǎn)無(wú)法得到“第二類(lèi)”這個(gè)結(jié)果CASE WHEN col_1 IN ( 'a', 'b') THEN '第一類(lèi)'WHEN col_1 IN ('a')       THEN '第二類(lèi)'ELSE'其他' END


下面我們來(lái)看一下,使用Case函數(shù)都能做些什么事情。 

一,已知數(shù)據(jù)按照另外一種方式進(jìn)行分組,分析。 

有如下數(shù)據(jù):(為了看得更清楚,我并沒(méi)有使用國(guó)家代碼,而是直接用國(guó)家名作為Primary Key) 

國(guó)家(country)人口(population)
中國(guó)600
美國(guó)100
加拿大100
英國(guó)200
法國(guó)300
日本250
德國(guó)200
墨西哥50
印度250


根據(jù)這個(gè)國(guó)家人口數(shù)據(jù),統(tǒng)計(jì)亞洲和北美洲的人口數(shù)量。應(yīng)該得到下面這個(gè)結(jié)果。 

人口
亞洲1100
北美洲250
其他700


想要解決這個(gè)問(wèn)題,你會(huì)怎么做?生成一個(gè)帶有洲Code的View,是一個(gè)解決方法,但是這樣很難動(dòng)態(tài)的改變統(tǒng)計(jì)的方式。 
如果使用Case函數(shù),SQL代碼如下:

SELECT  SUM(population),CASE countryWHEN '中國(guó)'     THEN '亞洲'WHEN '印度'     THEN '亞洲'WHEN '日本'     THEN '亞洲'WHEN '美國(guó)'     THEN '北美洲'WHEN '加拿大'  THEN '北美洲'WHEN '墨西哥'  THEN '北美洲'ELSE '其他' ENDFROM    Table_AGROUP BY CASE countryWHEN '中國(guó)'     THEN '亞洲'WHEN '印度'     THEN '亞洲'WHEN '日本'     THEN '亞洲'WHEN '美國(guó)'     THEN '北美洲'WHEN '加拿大'  THEN '北美洲'WHEN '墨西哥'  THEN '北美洲'ELSE '其他' END;


同樣的,我們也可以用這個(gè)方法來(lái)判斷工資的等級(jí),并統(tǒng)計(jì)每一等級(jí)的人數(shù)。SQL代碼如下; 

SELECTCASE WHEN salary <= 500 THEN '1'WHEN salary > 500 AND salary <= 600  THEN '2'WHEN salary > 600 AND salary <= 800  THEN '3'WHEN salary > 800 AND salary <= 1000 THEN '4'ELSE NULL END salary_class,
COUNT(*)FROM    Table_AGROUP BYCASE WHEN salary <= 500 THEN '1'WHEN salary > 500 AND salary <= 600  THEN '2'WHEN salary > 600 AND salary <= 800  THEN '3'WHEN salary > 800 AND salary <= 1000 THEN '4'ELSE NULL END;


二,用一個(gè)SQL語(yǔ)句完成不同條件的分組。 

有如下數(shù)據(jù) 

國(guó)家(country)性別(sex)人口(population)
中國(guó)1340
中國(guó)2260
美國(guó)145
美國(guó)255
加拿大151
加拿大249
英國(guó)140
英國(guó)260


按照國(guó)家和性別進(jìn)行分組,得出結(jié)果如下 

國(guó)家
中國(guó)340260
美國(guó)4555
加拿大5149
英國(guó)4060


普通情況下,用UNION也可以實(shí)現(xiàn)用一條語(yǔ)句進(jìn)行查詢(xún)。但是那樣增加消耗(兩個(gè)Select部分),而且SQL語(yǔ)句會(huì)比較長(zhǎng)。 
下面是一個(gè)是用Case函數(shù)來(lái)完成這個(gè)功能的例子 

SELECT country,
SUM( CASE WHEN sex = '1' THENpopulation ELSE 0 END),  --男性人口SUM( CASE WHEN sex = '2' THENpopulation ELSE 0 END)   --女性人口FROM  Table_AGROUP BY country;


這樣我們使用Select,完成對(duì)二維表的輸出形式,充分顯示了Case函數(shù)的強(qiáng)大。 

三,在Check中使用Case函數(shù)。 

在Check中使用Case函數(shù)在很多情況下都是非常不錯(cuò)的解決方法?赡苡泻芏嗳烁揪筒挥肅heck,那么我建議你在看過(guò)下面的例子之后也嘗試一下在SQL中使用Check。 
下面我們來(lái)舉個(gè)例子 
公司A,這個(gè)公司有個(gè)規(guī)定,女職員的工資必須高于1000塊。如果用Check和Case來(lái)表現(xiàn)的話(huà),如下所示

CONSTRAINT check_salary CHECK( CASE WHEN sex = '2'THEN CASE WHEN salary > 1000THEN 1 ELSE 0 ENDELSE 1 END = 1 )


如果單純使用Check,如下所示 

CONSTRAINT check_salary CHECK( sex = '2' AND salary > 1000 )


女職員的條件倒是符合了,男職員就無(wú)法輸入了。




  • 封印者輔助
  • 11全圖輔助
  • cs1.6作弊器
  • 英雄聯(lián)盟皮膚修改器
封印者輔助
(4)封印者輔助

封印者(Closers)一款在2016年最值得一玩的漫畫(huà)風(fēng)格動(dòng)作MORPG游戲。讓你們能夠在里面感受最豐富的游戲戰(zhàn)斗,不過(guò)畢竟是韓國(guó)那邊引進(jìn)的,難度或許會(huì)大些,這時(shí)就可以選擇封印者輔助,在游戲中更好的幫助你!減少很多的困難!

...更多>>
11全圖輔助
(6)11全圖輔助

起凡和11應(yīng)該是目前國(guó)內(nèi)最大的兩個(gè)對(duì)戰(zhàn)平臺(tái)了,浩方啥的都不在之列了。這里,小編給大家?guī)?lái)2016年最新的11全圖輔助,大多都是破解版的,免費(fèi)的少,東坡小編也不可能分享收費(fèi)輔助給大家,收費(fèi)的上哪兒都有得下。需要全圖上分的朋友們,別錯(cuò)過(guò)咯!

...更多>>
  • 逆戰(zhàn)暴雷超級(jí)輔助2.11 最新免費(fèi)版【

    04-08 / 405KB

    推薦理由:2015,是網(wǎng)游井噴的一年,各種大作不斷推出。逆戰(zhàn)雖說(shuō)是老游戲了,但有個(gè)好爹,其玩家數(shù)量也不在少數(shù)。逆戰(zhàn)
  • 阿杰dota真三全圖輔助sp1 官方最新

    03-10 / 3.5M

    推薦理由:​阿杰dota真三全圖輔助就是支持全圖對(duì)戰(zhàn)同名游戲放輔助工具。不但能夠支持跨平臺(tái)輔助,而且操作起來(lái)非
  • 小蘋(píng)果全圖9ss 綠色版

    11-27 / 6.0M

    推薦理由:小蘋(píng)果全圖(11對(duì)戰(zhàn)平臺(tái)Dota全圖掛)是最穩(wěn)定的11對(duì)戰(zhàn)平臺(tái)Dota全圖輔助。輔助綠色安全、無(wú)毒不封號(hào)。有需要
  • 笨笨熊妖妖全圖輔助(11全圖掛)V2 完

    06-16 / 15.5M

    推薦理由:因?yàn)?1對(duì)戰(zhàn)平臺(tái)的特殊性,所以笨笨熊妖妖全圖輔助是專(zhuān)門(mén)針對(duì)11對(duì)戰(zhàn)平臺(tái)開(kāi)發(fā)的全新11全圖掛。穩(wěn)定防封,超神
  • 11對(duì)戰(zhàn)平臺(tái)Panda全圖輔助12.0 免費(fèi)

    12-23 / 15.5M

    推薦理由:這是一款2016年最新的、專(zhuān)門(mén)針對(duì)11對(duì)戰(zhàn)平臺(tái)定制的一款全圖輔助。輔助是完全免費(fèi)的,穩(wěn)定使用,完美防封號(hào)!
  • 太極全圖(Dota全圖輔助)1.0 綠色免

    05-16 / 6.6M

    推薦理由:太極全圖是一個(gè)全新的Dota全圖輔助工具,支持最新的11平臺(tái)、VS平臺(tái)和浩方對(duì)戰(zhàn)平臺(tái),功能非常簡(jiǎn)單,能夠讓你
cs1.6作弊器
(15)cs1.6作弊器

cs,中文名反恐精英,游戲最早可以追溯到20世紀(jì),它可以算是第一人稱(chēng)射擊類(lèi)游戲的鼻祖。cs最經(jīng)典的版本當(dāng)屬1.5和1.6了,這里,小編給大家?guī)?lái)cs1.6作弊器,可以通用語(yǔ)豆客、175等平臺(tái),讓你能盡情的玩耍、暢快的裝逼。需要的朋友下載試試吧!

...更多>>
  • cs1.6傲視群雄腳本28.0 vip完整破解

    12-23 / 2.1M

    推薦理由:傲視群雄腳本是cs1.6比較經(jīng)典的一款腳本,盡管腳本已經(jīng)更新了很多代、很多代了,但是28.0依舊是使用的最多的
  • CS1.6過(guò)豆客透視作弊器2015.11 過(guò)豆

    11-17 / 703KB

    推薦理由:CS1.6過(guò)豆客透視作弊器擁有多達(dá)14項(xiàng)功能,透視自瞄、無(wú)后座力、防閃光煙霧等等,該作弊器是2015年11月出來(lái)的
  • cs1.6作弊防截圖工具

    07-23 / 1.9M

    推薦理由:最新cs1.6作弊防截圖工具,能過(guò)所有登陸器。讓你的輔助使用更加穩(wěn)定,100%不封!該工具完美支持1.5和1.6版本
  • cs1.6你狠迷人腳本ver 3.0 無(wú)堅(jiān)不摧

    12-24 / 3.7M

    推薦理由:你狠迷人是制作cs腳本的一個(gè)大神,出自X島。這里,小編給大家?guī)?lái)cs1.6你狠迷人腳本,最新的3.0無(wú)堅(jiān)不摧版,
  • CS1.6虐盟sxe多功能輔助15.3 完美破

    12-24 / 3.5M

    推薦理由:虐盟腳本可能不算特別出名,但是用過(guò)的應(yīng)該都會(huì)覺(jué)得好。功能可能不算多,但是穩(wěn)定、過(guò)sxe,并且小編帶來(lái)的腳
  • cs1.6火麒麟模型

    12-24 / 1.3M

    推薦理由:說(shuō)到火麒麟,想必大家第一時(shí)間會(huì)聯(lián)想到CF吧。小編這里給大家?guī)?lái)cs1.6火麒麟模型,讓你在cs中也能完美體驗(yàn)到
英雄聯(lián)盟皮膚修改器
(43)英雄聯(lián)盟皮膚修改器

在眾多的英雄聯(lián)盟玩家中很多人都購(gòu)買(mǎi)了各種自己喜歡的英雄的皮膚,但是很多皮膚的價(jià)格非常的昂貴,想要全部購(gòu)買(mǎi)需要不少的金錢(qián),通過(guò)英雄聯(lián)盟皮膚修改器可以在自己的電腦直接顯示各種自己想要的皮膚,有需要的擼友們就不要錯(cuò)過(guò)了。

...更多>>

相關(guān)評(píng)論

閱讀本文后您有什么感想? 已有 人給出評(píng)價(jià)!

  • 2791 喜歡喜歡
  • 2101 頂
  • 800 難過(guò)難過(guò)
  • 1219 囧
  • 4049 圍觀圍觀
  • 5602 無(wú)聊無(wú)聊
熱門(mén)評(píng)論
最新評(píng)論
第 1 樓 本機(jī)地址CZ88.NET 網(wǎng)友 客人 發(fā)表于: 2017/4/6 17:00:07
ddd

支持( 0 ) 蓋樓(回復(fù))

發(fā)表評(píng)論 查看所有評(píng)論(0)
昵稱(chēng):
表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
字?jǐn)?shù): 0/500 (您的評(píng)論需要經(jīng)過(guò)審核才能顯示)