PostgreSQL
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> PostgreSQL

Làm cách nào để chia kết quả truy vấn thành các cột riêng biệt?

Đây là cách tiếp cận có thể hơi tiết kiệm hơn bằng cách sử dụng mảng đa chiều .

Vui lòng không bao giờ, không bao giờ, không bao giờ sử dụng truy vấn sau:

CREATE EXTENSION tablefunc;

SELECT * FROM crosstab(
  'SELECT ''row1''::text, width_bucket(x, 1, 53001, 100), array_agg(x order by x)::integer[] from generate_series(1,53000) x GROUP BY 2'
) ct(
 rowname text,
    col1 integer[], col2 integer[], col3 integer[], col4 integer[], col5
    integer[], col6 integer[], col7 integer[], col8 integer[], col9 integer[],
    col10 integer[], col11 integer[], col12 integer[], col13 integer[], col14
    integer[], col15 integer[], col16 integer[], col17 integer[], col18 integer[],
    col19 integer[], col20 integer[], col21 integer[], col22 integer[], col23
    integer[], col24 integer[], col25 integer[], col26 integer[], col27 integer[],
    col28 integer[], col29 integer[], col30 integer[], col31 integer[], col32
    integer[], col33 integer[], col34 integer[], col35 integer[], col36 integer[],
    col37 integer[], col38 integer[], col39 integer[], col40 integer[], col41
    integer[], col42 integer[], col43 integer[], col44 integer[], col45 integer[],
    col46 integer[], col47 integer[], col48 integer[], col49 integer[], col50
    integer[], col51 integer[], col52 integer[], col53 integer[], col54 integer[],
    col55 integer[], col56 integer[], col57 integer[], col58 integer[], col59
    integer[], col60 integer[], col61 integer[], col62 integer[], col63 integer[],
    col64 integer[], col65 integer[], col66 integer[], col67 integer[], col68
    integer[], col69 integer[], col70 integer[], col71 integer[], col72 integer[],
    col73 integer[], col74 integer[], col75 integer[], col76 integer[], col77
    integer[], col78 integer[], col79 integer[], col80 integer[], col81 integer[],
    col82 integer[], col83 integer[], col84 integer[], col85 integer[], col86
    integer[], col87 integer[], col88 integer[], col89 integer[], col90 integer[],
    col91 integer[], col92 integer[], col93 integer[], col94 integer[], col95
    integer[], col96 integer[], col97 integer[], col98 integer[], col99 integer[],
    col100 integer[]
);

Cách chính xác để giải quyết vấn đề này gần như chắc chắn trong ứng dụng của bạn . SQL tốt ở nhiều thứ. Đây không phải là một trong số chúng, đặc biệt là trong PostgreSQL với sự hỗ trợ trục rất hạn chế của nó. Trong bất kỳ cơ sở dữ liệu nào, điều này sẽ là một điều điên rồ để làm.

Theo như tôi lo lắng, nếu tôi phải sử dụng một truy vấn chỉ để tạo danh sách cột, đó là dấu hiệu hệ thống đang bị buộc phải làm điều gì đó mà nó không phù hợp cho:

select string_agg('col'||n||' integer[]',', ') FROM generate_series(1,100) n;



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Tránh bế tắc PostgreSQL khi thực hiện cập nhật hàng loạt và thao tác xóa

  2. Không thể trộn các phép nối rõ ràng và không rõ ràng với Có một mục nhập cho bảng ... nhưng nó không thể được tham chiếu từ phần này của truy vấn

  3. Buộc cài đặt Postgres bằng mã hóa UTF8, không phải LATIN1?

  4. Cách kiểm tra xem một dịch vụ mà tôi không biết tên có đang chạy trên Ubuntu hay không

  5. SAO CHÉP với tên tệp động