Oracle SQL的REGEXP_REPLACE 與條二維矩陣類比SQL語句

來源:互聯網
上載者:User

分享兩條SQL語句

1,Oracle的SQL支援的REGEXP_REPLACE

SQL> select regexp_replace('fuck you','(.)(.)','/2/1') from dual;
 
REGEXP_REPLACE('FUCKYOU','(.)(
------------------------------
ufkcy uo

(呵呵)

字母兩個兩個一對,全倒過來了

/////////////////////////////////////////////////////////////////////////////

SQL> select regexp_replace('fuck you','(.)(.)','/2/3') from dual;
 
REGEXP_REPLACE('FUCKYOU','(.)(
------------------------------
ukyu

剔除了所有奇數位置上的字元,只留下偶數位置的字元,空格是奇數位置的字元

 

2,使用SQL語句類比二維矩陣

思路:首先用Cross Join構造出一個完全二維表,然後進行排序,分組

用到的表:EMP表,至少有三個欄位,DEPTNO,JOB,SAL

DEPTNO,JOB構成聯合主鍵,SAL的值由DEPTNO和JOB兩個欄位所決定,SAL的值有可能是NULL,要求:當SAL值為空白時,顯示0

 

SELECT A.DEPTNO,B.JOB,
(
CASE
WHEN EXISTS (SELECT * FROM EMP WHERE DEPTNO=A.DEPTNO AND JOB=B.JOB) THEN
    (
    SELECT SUM(SAL)
    FROM EMP
    WHERE DEPTNO=A.DEPTNO AND JOB=B.JOB
    GROUP BY DEPTNO,JOB
    )  
ELSE 0
END
) SUM_SAL
FROM
    (
    SELECT DISTINCT DEPTNO
    FROM EMP
    ) A
    CROSS JOIN
    (
    SELECT DISTINCT JOB
    FROM EMP
    ) B
GROUP BY A.DEPTNO,B.JOB
ORDER BY A.DEPTNO,B.JOB

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.