Menggunakan LIKE dalam SQL JOIN
Dalam SQL, melakukan operasi JOIN selalunya memerlukan penetapan keadaan padanan antara lajur daripada jadual yang berbeza. Satu syarat sedemikian melibatkan pemadanan lajur daripada jadual A dengan lajur daripada jadual B, di mana kandungan lajur B boleh berbeza-beza sebelum atau selepas kandungan lajur A. Senario ini memerlukan penggunaan operator LIKE.
Untuk mencapai ini, anda mempunyai beberapa pilihan:
<code class="sql">SELECT * FROM TABLE a JOIN TABLE b ON INSTR(b.column, a.column) > 0</code>
Di sini, INSTR() mengembalikan kedudukan yang pertama kemunculan nilai lajur A dalam lajur B. Baris yang sepadan ialah baris yang kedudukannya lebih besar daripada 0.
<code class="sql">SELECT * FROM TABLE a JOIN TABLE b ON b.column LIKE '%'+ a.column +'%'</code>
Kaedah ini menambahkan kad bebas pada kedua-dua belah nilai lajur A, membenarkan mana-mana aksara mendahului atau mengikutinya dalam lajur B.
<code class="sql">SELECT * FROM TABLE a JOIN TABLE b ON b.column LIKE CONCAT('%', a.column ,'%')</code>
Sama seperti pendekatan sebelumnya, kaedah ini membina rentetan dengan kad bebas pada kedua-dua sisi nilai lajur A menggunakan fungsi CONCAT().
Untuk memastikan padanan tidak sensitif huruf besar-besaran, ia adalah disyorkan untuk menukar kedua-dua lajur kepada huruf besar sebelum membandingkannya. Ini boleh dicapai dengan menggunakan fungsi UPPER().
Perhatikan bahawa kaedah yang paling cekap akan bergantung pada pangkalan data dan data khusus yang terlibat, seperti yang ditentukan dengan memeriksa output rancangan EXPLAIN.
Atas ialah kandungan terperinci Bagaimanakah anda boleh melakukan operasi JOIN di mana keadaan padanan melibatkan lajur daripada satu jadual yang mengandungi subrentetan lajur daripada jadual lain?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!