Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

एक कॉलम में दोहराए जाने वाले मान

Oracle सेटअप :

CREATE TABLE your_table ( your_list_column ) AS
  SELECT 'a,a,b,c,d' FROM DUAL UNION ALL -- duplicates both at head
  SELECT 'a,b,a,c,d' FROM DUAL UNION ALL -- duplicates at head and middle
  SELECT 'a,b,c,d,a' FROM DUAL UNION ALL -- duplicates at head and tail
  SELECT 'a,b,b,c,d' FROM DUAL UNION ALL -- duplicates at middle and next item
  SELECT 'a,b,c,b,d' FROM DUAL UNION ALL -- duplicates at middle and middle
  SELECT 'a,b,c,d,b' FROM DUAL UNION ALL -- duplicates at middle and tail
  SELECT 'a,b,c,d,d' FROM DUAL UNION ALL -- duplicates both at tail
  SELECT 'a,b,a,c,b' FROM DUAL UNION ALL -- two pairs of duplicates
  SELECT 'a,b,c,d,e' FROM DUAL;          -- no duplicates

बार-बार मान वाली सूचियां प्राप्त करने के लिए, आप रेगुलर एक्सप्रेशन में बैक-रेफरेंस का उपयोग कर सकते हैं:

SELECT *
FROM   your_table
WHERE  REGEXP_LIKE( ',' || your_list_column || ',', ',([^,]+),(.+,)?\1,' )

आउटपुट :

YOUR_LIST_COLUMN
----------------
a,a,b,c,d
a,b,a,c,d
a,b,c,d,a
a,b,b,c,d
a,b,c,b,d
a,b,c,d,b
a,b,c,d,d
a,b,a,c,b

पहला दोहराया मूल्य प्राप्त करने के लिए आप उपरोक्त नियमित अभिव्यक्ति के पहले उप-समूह को निकाल सकते हैं:

SELECT your_list_column,
       REGEXP_SUBSTR( ',' || your_list_column || ',', ',([^,]+),(.+,)?\1,', 1, 1, NULL, 1 )
         AS duplicate_value
FROM   your_table
WHERE  REGEXP_LIKE( ',' || your_list_column || ',', ',([^,]+),(.+,)?\1,' )

आउटपुट :

YOUR_LIST_COLUMN DUPLICATE VALUE
---------------- ---------------
a,a,b,c,d        a
a,b,a,c,d        a
a,b,c,d,a        a
a,b,b,c,d        b
a,b,c,b,d        b
a,b,c,d,b        b
a,b,c,d,d        d
a,b,a,c,b        a

अद्वितीय मान प्राप्त करने के लिए, split_string() . का उपयोग करें यहां परिभाषित के रूप में कार्य करें (लेकिन पूर्व-निर्धारित VARRAY . के बजाय उपयोगकर्ता द्वारा परिभाषित प्रकार का उपयोग करना ):

CREATE OR REPLACE TYPE stringlist IS TABLE OF VARCHAR2(4000);
/

CREATE OR REPLACE FUNCTION split_String(
  i_str    IN  VARCHAR2,
  i_delim  IN  VARCHAR2 DEFAULT ','
) RETURN stringlist DETERMINISTIC
AS
  p_result       stringlist := stringlist();
  p_start        NUMBER(5) := 1;
  p_end          NUMBER(5);
  c_len CONSTANT NUMBER(5) := LENGTH( i_str );
  c_ld  CONSTANT NUMBER(5) := LENGTH( i_delim );
BEGIN
  IF c_len > 0 THEN
    p_end := INSTR( i_str, i_delim, p_start );
    WHILE p_end > 0 LOOP
      p_result.EXTEND;
      p_result( p_result.COUNT ) := SUBSTR( i_str, p_start, p_end - p_start );
      p_start := p_end + c_ld;
      p_end := INSTR( i_str, i_delim, p_start );
    END LOOP;
    IF p_start <= c_len + 1 THEN
      p_result.EXTEND;
      p_result( p_result.COUNT ) := SUBSTR( i_str, p_start, c_len - p_start + 1 );
    END IF;
  END IF;
  RETURN p_result;
END;
/

फिर आप इसे SET() . के संयोजन में उपयोग कर सकते हैं संग्रह समारोह:

SELECT t.*,
       (
         SELECT LISTAGG( COLUMN_VALUE, ',' ) WITHIN GROUP ( ORDER BY ROWNUM )
         FROM   TABLE( SET( split_string( t.your_list_column ) ) )
       ) AS unique_list
FROM   your_table t

आउटपुट :

YOUR_LIST_COLUMN UNIQUE_LIST
---------------- ---------------
a,a,b,c,d        a,b,c,d
a,b,a,c,d        a,b,c,d
a,b,c,d,a        a,b,c,d
a,b,b,c,d        a,b,c,d
a,b,c,b,d        a,b,c,d
a,b,c,d,b        a,b,c,d
a,b,c,d,d        a,b,c,d
a,b,a,c,b        a,b,c
a,b,c,d,e        a,b,c,d,e


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracleपैरामीटर और IN क्लॉज

  2. ऑरैकल में शून्य बाधा कैसे उत्पन्न करें?

  3. Oracle अनुक्रम ट्रिगर बनाना

  4. एकाधिक csv फ़ाइलों में तालिका निर्यात करने की प्रक्रिया

  5. Oracle में RTRIM () फ़ंक्शन