Fasal PILIHAN PostgreSQL: Kelakuan Berbilang Fungsi Pengembalian Set
Interaksi berbilang fungsi pengembalian set (SRF) dalam klausa PostgreSQL SELECT
adalah bergantung kepada versi. Memahami tingkah laku ini adalah penting untuk hasil pertanyaan yang boleh diramal.
PostgreSQL 10 dan Kemudian:
Dalam PostgreSQL 10 dan versi seterusnya, SRF diproses sebelum ungkapan skalar dalam senarai SELECT
. Ini secara fungsinya setara dengan menggunakannya dalam klausa LATERAL FROM
. Sistem menjana baris output secara berulang: pertama menggunakan hasil awal daripada setiap SRF, kemudian hasil kedua daripada setiap SRF, dan seterusnya.
Jika SRF mengembalikan kiraan baris yang berbeza-beza, hasil yang lebih pendek dipadatkan dengan nilai NULL
untuk memadankan panjang set hasil terpanjang. Ini memastikan semua baris output mempunyai bilangan lajur yang sama.
PostgreSQL 9.6 dan Terdahulu:
Versi lama (9.6 dan ke bawah) mempamerkan gelagat yang berbeza. Jumlah bilangan baris keluaran menjadi gandaan sepunya terkecil (LCM) bagi kiraan baris yang dijana oleh setiap SRF. Ini boleh membawa kepada hasil yang tidak dijangka dan berkemungkinan tidak dapat diramalkan, terutamanya apabila saiz set keputusan SRF tidak berkongsi pembahagi biasa.
Amalan Terbaik:
Untuk mengelakkan kekaburan dan memastikan hasil yang konsisten merentas versi PostgreSQL, sangat dinasihatkan untuk mengelak daripada menggunakan berbilang SRF secara langsung dalam senarai SELECT
, terutamanya dalam versi PostgreSQL yang lebih lama. Gabungan LATERAL
menyediakan pendekatan yang lebih jelas, lebih boleh diramal dan serasi versi silang untuk mengendalikan berbilang SRF.
Bacaan Selanjutnya:
Atas ialah kandungan terperinci Bagaimanakah Fungsi Berbilang Set-Returning Berkelakuan dalam Klausa SELECT PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!