Laravel: Mencapai Pengesahan Unik Merentasi Berbilang Lajur Jadual
Untuk senario di mana anda mempunyai pangkalan data dengan jadual yang mengandungi berbilang lajur yang gabungannya mesti kekal unik , adalah perlu untuk menguatkuasakan kekangan keunikan ini dalam aplikasi Laravel anda.
Salah satu contoh sedemikian ialah jadual 'pelayan' dengan lajur 'ip' dan 'nama hos'. Anda ingin memastikan bahawa gabungan 'ip' dan 'nama hos' tertentu adalah unik, walaupun nilai 'ip' atau 'nama hos' individu mungkin muncul beberapa kali.
Penyelesaian Menggunakan Peraturan:: unique()
Untuk melaksanakan pengesahan ini, gunakan kaedah Rule::unique. Kaedah ini membolehkan anda menentukan peraturan unik tersuai pada set lajur tertentu. Berikut ialah contoh:
<code class="php">$messages = [ 'data.ip.unique' => 'Given ip and hostname are not unique', ]; Validator::make($data, [ 'data.ip' => [ 'required', Rule::unique('servers') ->where(function ($query) use ($ip, $hostname) { return $query->where('ip', $ip) ->where('hostname', $hostname); }), ], ], $messages);</code>
Penjelasan
Dengan melaksanakan peraturan ini, anda memastikan aplikasi anda tidak membenarkan gabungan pendua 'ip' dan 'nama hos' dalam jadual 'pelayan'.
Atas ialah kandungan terperinci Bagaimana untuk Menguatkuasakan Pengesahan Unik Merentas Berbilang Lajur dalam Laravel?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!