Menggabungkan Lajur Rentetan dalam Pernyataan SELECT PostgreSQL
PostgreSQL menawarkan beberapa kaedah untuk menggabungkan lajur rentetan dalam pertanyaan SELECT
. Penggabungan terus menggunakan operator ||
mungkin menimbulkan cabaran jika jenis data lajur tidak konsisten.
Penghantaran Jenis Eksplisit
Untuk memastikan penyatuan yang lancar, hantar lajur secara eksplisit ke text
jenis data:
<code class="language-sql">SELECT a::text || b FROM foo;</code>
Ini menjamin kedua-dua a
dan b
dianggap sebagai teks sebelum penyatuan.
Memanfaatkan Huruf Rentetan
Memasukkan literal rentetan dalam ungkapan penggabungan ialah satu lagi pendekatan yang berkesan. Literal secara tersirat dianggap sebagai text
:
<code class="language-sql">SELECT a || ',' || b FROM foo;</code>
Contoh ini memasukkan koma sebagai pemisah antara nilai yang digabungkan.
Menggunakan Fungsi Penggabungan
Untuk penggabungan yang lebih mantap merentas pelbagai jenis data, pertimbangkan fungsi ini:
concat_ws()
: Fungsi ini memasukkan pemisah antara nilai bukan NULL.concat()
: Fungsi ini menggabungkan nilai tanpa sebarang pemisah.Kedua-dua concat_ws()
dan concat()
mempunyai turun naik IMMUTABLE
, menjadikannya sesuai untuk digunakan dalam indeks atau skim pembahagian.
Pertimbangan Penting
untuk penyatuan rentetan; ia bukan SQL standard untuk tujuan ini.text
atau varchar
jenis data berbanding character()
untuk lajur rentetan.Dengan menggunakan teknik ini, anda boleh menggabungkan lajur dengan pasti dalam pertanyaan PostgreSQL SELECT
anda, mencapai hasil yang tepat dan konsisten.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggabungkan Lajur dengan Berkesan dalam Pertanyaan SELECT PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!