91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle用decode函數或CASE-WHEN實現自定義排序的方法

發布時間:2020-07-23 16:51:28 來源:億速云 閱讀:392 作者:小豬 欄目:數據庫

這篇文章主要講解了Oracle用decode函數或CASE-WHEN實現自定義排序的方法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

1 問題

SQL排序,只要在order by后面加字段就可以了,可以通過加descasc來選擇降序或升序。但排序規則是默認的,數字、時間、字符串等都有自己默認的排序規則。有時候需要按自己的想法來排序,而不是按字段默認排序規則。

比如字段值為英文字段:MondayTuesdayWednesday等,如果按字段默認排序規則就為:

Friday
Monday
Saturday
Sunday
Thursday
Tuesday
Wednesday

實際我需要的是:

Monday
Tuesday
Wednesday
Thursday
Friday
Saturday
Sunday

2 decode函數

通過decode函數可以實現,如下:

select * from table_date
order by 
decode(DateStr,
  'Monday',1
  'Tuesday',2
  'Wednesday',3
  'Thursday',4
  'Friday',5
  'Saturday',6
  'Sunday',7,
  0);

后面的數字可以不連續。

3 case when語句

另外,還可以用case when來實現:

select * from table_date
order by (CASE DateStr
  WHEN 'Monday' then 1
  WHEN 'Tuesday' then 2
  WHEN 'Wednesday' then 3
  WHEN 'Thursday' then 4
  WHEN 'Friday' then 5
  WHEN 'Saturday' then 6
  WHEN 'Sunday' then 7
   ELSE 0
   END);

4 總結

當然,把字段直接賦值為對應的數字效率會高很多,通過另外一張表再建立映射關系。

看完上述內容,是不是對Oracle用decode函數或CASE-WHEN實現自定義排序的方法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

福鼎市| 同德县| 凤翔县| 建阳市| 广元市| 宁明县| 重庆市| 临高县| 漠河县| 杭锦后旗| 黄骅市| 黄龙县| 开封市| 台北市| 凤凰县| 都兰县| 永修县| 墨玉县| 鄂托克旗| 广州市| 巫山县| 河南省| 琼海市| 金秀| 班戈县| 扎囊县| 丽江市| 丹巴县| 凯里市| 永靖县| 临夏市| 吴旗县| 乌恰县| 贵德县| 卓尼县| 江达县| 庆云县| 营口市| 德格县| 邹平县| 黔西县|