cari
Rumahpangkalan datatutorial mysqlBagaimana untuk Menguatkuasakan Kekangan Unik dalam PostgreSQL dengan Lajur NULL?

How to Enforce Unique Constraints in PostgreSQL with NULL Columns?

Kekangan Unik PostgreSQL dan Lajur NULL: Panduan Praktikal

Mengendalikan kekangan unik dalam PostgreSQL apabila berurusan dengan lajur boleh batal memerlukan pertimbangan yang teliti. Bayangkan jadual dengan lajur UserId, MenuId dan RecipeId, dengan UserId dan RecipeId bukan nol. Kekangan unik standard pada lajur ini akan membenarkan entri pendua jika MenuId berbeza, termasuk nilai NULL.

Berikut ialah strategi yang berkesan untuk menangani perkara ini:

PostgreSQL 15 dan Versi Kemudian

PostgreSQL 15 memperkenalkan klausa NULLS NOT DISTINCT, menyediakan penyelesaian yang mudah. Klausa ini menganggap nilai NULL sebagai sama apabila menguatkuasakan keunikan dalam kekangan dan indeks:

ALTER TABLE favorites
ADD CONSTRAINT favo_uni UNIQUE NULLS NOT DISTINCT (user_id, menu_id, recipe_id);

PostgreSQL 14 dan Versi Terdahulu

Untuk versi PostgreSQL yang lebih lama, pendekatan yang disyorkan melibatkan penciptaan indeks separa:

CREATE UNIQUE INDEX favo_3col_uni_idx ON favorites (user_id, menu_id, recipe_id)
WHERE menu_id IS NOT NULL;

CREATE UNIQUE INDEX favo_2col_uni_idx ON favorites (user_id, recipe_id)
WHERE menu_id IS NULL;

Ini secara berkesan menguatkuasakan keunikan dengan mencipta indeks berasingan untuk baris di mana menu_id adalah NULL dan di mana ia BUKAN NULL.

Pertimbangan Penting untuk Indeks Separa

Menggunakan indeks separa memperkenalkan beberapa had:

  • Kekangan kunci asing tidak boleh digunakan terus pada gabungan tiga lajur (user_id, menu_id, recipe_id).
  • Pengelompokkan berdasarkan indeks separa tidak disokong.
  • Pertanyaan kekurangan klausa WHERE padanan tidak akan menggunakan indeks separa.

Amalan Terbaik:

Adalah dinasihatkan untuk menggunakan pengecam huruf kecil (cth., favorites) dalam PostgreSQL untuk konsistensi dan untuk mengelakkan kemungkinan isu. Memilih kaedah yang sesuai bergantung pada versi PostgreSQL anda dan keperluan khusus. Klausa NULLS NOT DISTINCT menawarkan penyelesaian yang lebih bersih dalam versi yang lebih baharu, manakala indeks separa menyediakan alternatif berfungsi untuk versi yang lebih lama.

Atas ialah kandungan terperinci Bagaimana untuk Menguatkuasakan Kekangan Unik dalam PostgreSQL dengan Lajur NULL?. 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
Bagaimana saya menggugurkan atau mengubahsuai pandangan yang ada di mysql?Bagaimana saya menggugurkan atau mengubahsuai pandangan yang ada di mysql?May 16, 2025 am 12:11 AM

TODROPAVIEWInMYSQL, gunakan "dropviewififeXistsview_name;" andTomodifyAview, gunakan "createorreplaceviewview_nameasSelect ..."

Pandangan MySQL: Corak reka bentuk mana yang boleh saya gunakan dengannya?Pandangan MySQL: Corak reka bentuk mana yang boleh saya gunakan dengannya?May 16, 2025 am 12:10 AM

Mysqlviewscaneffectivetyutilizedesignpatternslikeadapter, penghias, kilang, andobserver.1) adapterpaternaptsdatafromdifferenttablesintoaunifiedview.2)

Apakah kelebihan menggunakan pandangan di MySQL?Apakah kelebihan menggunakan pandangan di MySQL?May 16, 2025 am 12:09 AM

ViewsinmysqlarebeneficialforsImplifingceMlexqueries, Enhancingsecurity, MemastikanDataconsistency, andoptimizingperformance

Bagaimana saya boleh membuat pandangan mudah di mysql?Bagaimana saya boleh membuat pandangan mudah di mysql?May 16, 2025 am 12:08 AM

TOCREATEASIMPLEVIEWInMYSQL, USETHECreatEviewStatement.1) definetheViewWithCreateViewView_nameas.2)

MySQL Buat Penyataan Pengguna: Contoh dan Kesalahan BiasaMySQL Buat Penyataan Pengguna: Contoh dan Kesalahan BiasaMay 16, 2025 am 12:04 AM

TOCReateUsersinMysql, UsethecreateUserStatement.1) Foralocaluser: createuser'localuser '@' localhost'identifiedby'SecureShword '; 2) foraremoteuser: createuser'remoteuser'@'%'

Apakah batasan menggunakan pandangan di MySQL?Apakah batasan menggunakan pandangan di MySQL?May 14, 2025 am 12:10 AM

Mysqlviewshavelimitations: 1) theDon'tsupportallsqloperations, bintikDatamanipulationThroughviewswithjoinsorsubqueries.2) merekacanimpactperformance, terutamanya dengan komplekssum

Faktor apa yang mempengaruhi bilangan pencetus yang boleh saya gunakan di MySQL?Faktor apa yang mempengaruhi bilangan pencetus yang boleh saya gunakan di MySQL?May 14, 2025 am 12:08 AM

Mysqldoes'timposeahardlimitontriggers, butpracticalfactorsDeterminetheirefectiveus

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Nordhold: Sistem Fusion, dijelaskan
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
<🎜> obscur: Ekspedisi 33 - Cara mendapatkan pemangkin Chroma yang sempurna
2 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual