Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Menguatkuasakan Pengesahan Unik Merentas Berbilang Lajur dalam Laravel?

Bagaimana untuk Menguatkuasakan Pengesahan Unik Merentas Berbilang Lajur dalam Laravel?

DDD
DDDasal
2024-10-30 06:35:02315semak imbas

How to Enforce Unique Validation Across Multiple Columns in Laravel?

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

  • Penutupan 'where()' membolehkan anda menentukan kekangan tambahan pada peraturan keunikan. Dalam kes ini, ia menyatakan bahawa kedua-dua lajur 'ip' dan 'nama hos' mesti sepadan untuk pengesahan gagal.
  • Kaedah 'unik()' membolehkan anda menentukan jadual di mana peraturan unik harus digunakan . Dalam kes ini, ia adalah jadual 'pelayan'.
  • Peraturan 'diperlukan' memastikan pengguna memberikan nilai 'ip'.
  • Susun atur 'mesej' menyesuaikan mesej ralat yang dipaparkan jika pengesahan gagal.

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn