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

डायनामिक कॉलम हेडर पोस्टग्रेज करता है (किसी अन्य टेबल से)

जवाब के आधार पर (दूसरे टेबल से) (एरिक वल्लभ मिनिकेल का काम) मैंने फ़ंक्शन को अधिक लचीला और सुविधाजनक बनाने के लिए सुधार किया। मुझे लगता है कि यह दूसरों के लिए भी उपयोगी हो सकता है, विशेष रूप से क्योंकि यह केवल पीजी/पीएलएसक्यूएल पर निर्भर करता है और एरिक्स काम के अन्य व्युत्पन्न (यानी प्लापीथन) के रूप में विस्तार की स्थापना की आवश्यकता नहीं है। टेस्टेट 9.3.5 के साथ लेकिन कम से कम 9.2 तक काम करना चाहिए।

सुधार:

  • रिक्त स्थान वाले पिवोटेड कॉलम नामों से निपटें
  • एकाधिक पंक्ति शीर्षलेख कॉलम से निपटें
  • पिवट सेल के साथ-साथ गैर-एग्रीगेटेड पिवट सेल में एग्रीगेट फंक्शन के साथ डील करें (अंतिम पैरामीटर 'योग (सेलवाल)' के साथ-साथ 'सेलवाल' भी हो सकता है, अगर अंडरलाइंग टेबल/व्यू पहले से एग्रीगेशन करता है)
  • पिवट सेल के डेटा प्रकार का स्वतः पता लगाएं (इसे अब फ़ंक्शन में पास करने की आवश्यकता नहीं है)

उपयोग:

SELECT get_crosstab_statement('table_to_pivot', ARRAY['rowname' [, <other_row_header_columns_as_well>], 'colname', 'max(cellval)');

कोड:

CREATE OR REPLACE FUNCTION get_crosstab_statement(tablename character varying, row_header_columns character varying[], pivot_headers_column character varying, pivot_values character varying)
  RETURNS character varying AS
$BODY$
--returns the sql statement to use for pivoting the table
--based on: http://www.cureffi.org/2013/03/19/automatically-creating-pivot-table-column-names-in-postgresql/
--based on: https://stackoverflow.com/questions/4104508/postgres-dynamic-column-headers-from-another-table
--based on: http://www.postgresonline.com/journal/categories/24-tablefunc

DECLARE
    arrayname CONSTANT character varying := 'r';

    row_headers_simple character varying;
    row_headers_quoted character varying;
    row_headers_castdown character varying;
    row_headers_castup character varying;
    row_header_count smallint;
    row_header record;

    pivot_values_columnname character varying;
    pivot_values_datatype character varying;
    pivot_headers_definition character varying;
    pivot_headers_simple character varying;

    sql_row_headers character varying;
    sql_pivot_headers character varying;
    sql_crosstab_result character varying;

BEGIN
    -- 1. create row header definitions
    row_headers_simple   :=         array_to_string(row_header_columns, ', ');
    row_headers_quoted   := '''' || array_to_string(row_header_columns, ''', ''') || '''';
    row_headers_castdown :=         array_to_string(row_header_columns, '::text, ') || '::text';

    row_header_count     := 0;
    sql_row_headers      := 'SELECT column_name, data_type
                            FROM information_schema.columns
                            WHERE table_name = ''' || tablename || ''' AND column_name IN (' || row_headers_quoted || ')';
    FOR row_header IN EXECUTE sql_row_headers LOOP
        row_header_count := row_header_count + 1;
        row_headers_castup := COALESCE(row_headers_castup || ', ', '') || arrayname || '[' || row_header_count || ']::' || row_header.data_type || ' AS ' || row_header.column_name;
    END LOOP;

    -- 2. retrieve basic column name in case an aggregate function is used
    SELECT coalesce(substring(pivot_values FROM '.*\((.*)\)'), pivot_values)
    INTO pivot_values_columnname;

    -- 3. retrieve pivot values datatype
    SELECT data_type
    FROM information_schema.columns
    WHERE table_name = tablename AND column_name = pivot_values_columnname
    INTO pivot_values_datatype;

    -- 4. retrieve list of pivot column names.
    sql_pivot_headers := 'SELECT string_agg(DISTINCT quote_ident(' || pivot_headers_column || '), '', '' ORDER BY quote_ident(' || pivot_headers_column || ')) as names, string_agg(DISTINCT quote_ident(' || pivot_headers_column || ') || '' ' || pivot_values_datatype || ''', '', '' ORDER BY quote_ident(' || pivot_headers_column || ') || '' ' || pivot_values_datatype || ''') as definitions FROM ' || tablename || ';';
    EXECUTE sql_pivot_headers INTO pivot_headers_simple, pivot_headers_definition;

    -- 5. set up the crosstab query
    sql_crosstab_result := 'SELECT  ' || replace (row_headers_castup || ', ' || pivot_headers_simple, ', ', ',
        ') || '
FROM    crosstab (
        ''SELECT ARRAY[' || row_headers_castdown || '] AS ' || arrayname || ', ' || pivot_headers_column || ', ' || pivot_values || '
        FROM ' || tablename || '
        GROUP BY ' || row_headers_simple || ', ' || pivot_headers_column || (CASE pivot_values_columnname=pivot_values WHEN true THEN ', ' || pivot_values ELSE '' END) || '
        ORDER BY ' || row_headers_simple || '''
    ,
        ''SELECT DISTINCT ' || pivot_headers_column || '
        FROM ' || tablename || '
        ORDER BY ' || pivot_headers_column || '''
    ) AS newtable (
        ' || arrayname || ' varchar[]' || ',
        ' || replace(pivot_headers_definition, ', ', ',
        ') || '
    );';

    RETURN sql_crosstab_result;
 END

 $BODY$
  LANGUAGE plpgsql STABLE
  COST 100;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL:टाइमस्टैम्प फ़ील्ड पर पसंद के साथ डेटा का चयन करें

  2. संबंधित मॉडल को शामिल करते समय उत्सुक लोडिंग त्रुटि को अनुक्रमित करें

  3. npqsql का उपयोग करके पोस्टग्रेस्क्ल और डैपर के साथ AsyncQuery

  4. कठपुतली और कष्टप्रद चेतावनी पोस्टग्रेज:पोस्टग्रेस्क्ल को पासिंग संस्करण ::सर्वर पदावनत है

  5. प्रत्येक N मानों को समूहीकृत करना