Bagaimana untuk Menguatkuasakan Pengesahan Unik Merentas Berbilang Lajur dalam Laravel?

DDD
Lepaskan: 2024-10-30 06:35:02
asal
252 orang telah melayarinya

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>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!