Oracle case when then else end的兩種用法


查詢表結構

  

SELECT 
       T.COLUMN_ID,
       T.COLUMN_NAME,
       (CASE
         WHEN (T.DATA_TYPE = 'VARCHAR2' OR T.DATA_TYPE = 'RAW') THEN
          T.DATA_TYPE || '(' || T.DATA_LENGTH || ')'
         WHEN (T.DATA_TYPE = 'NUMBER' AND T.DATA_PRECISION IS NOT NULL) THEN
          T.DATA_TYPE || '(' || T.DATA_PRECISION || ',' || T.DATA_SCALE || ')'
         ELSE
          T.DATA_TYPE
       END) AS DATA_TYPE,
       B.COMMENTS
  FROM USER_TAB_COLUMNS T
 INNER JOIN ALL_COL_COMMENTS B
    ON B.COLUMN_NAME = T.COLUMN_NAME
   AND T.TABLE_NAME = B.TABLE_NAME
   AND T.TABLE_NAME = 'T_WEIXIN_REMIND_FUND_CHANGE'
 ORDER BY T.COLUMN_ID;

  第二種:紅色部分可以把 T.DATA_TYPE 字段移動到CASE,WHEN 之間,這樣when之后就直接寫DATA_TYPE對應的值即可

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM