Rumah > Artikel > pangkalan data > Bolehkah saya Menyertai Jadual dengan Nilai Terpisah Koma bertitik dalam Lajur Menggunakan MySQL Tulen?
Bolehkah saya menyelesaikan masalah ini dengan mysql tulen? (menyertai pada ';' nilai dipisahkan dalam lajur)
Soalan:
Diberikan dua jadual, jadual pengguna t1 dengan lajur sumber yang mengandungi '; ' ID sumber yang dipisahkan dan jadual sumber t2 dengan ID dan data, anda mahu menyertai t1 dan t2 untuk mendapatkan jadual dengan data pengguna dan sumber.
Masalah:
Anda tidak boleh menggunakan bahasa luar untuk memanipulasi hasil dan jadual user_resources dinyahnormalkan.
Penyelesaian:
Buat jadual yang dipanggil integerseries dengan nombor dari 1 hingga had tertentu. Gunakan fungsi COUNT_IN_SET dan VALUE_IN_SET, yang menganggap lajur sumber sebagai tatasusunan, untuk menormalkan jadual. Kemudian sertai dengan integerseries untuk mengekstrak ID sumber individu.
<code class="sql">SELECT user_resource.user, resource.data FROM user_resource JOIN integerseries AS isequence ON isequence.id <= COUNT_IN_SET(user_resource.resources, ';') JOIN resource ON resource.id = VALUE_IN_SET(user_resource.resources, ';', isequence.id) ORDER BY user_resource.user, resource.data</code>
Atas ialah kandungan terperinci Bolehkah saya Menyertai Jadual dengan Nilai Terpisah Koma bertitik dalam Lajur Menggunakan MySQL Tulen?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!