Rumah > pangkalan data > tutorial mysql > Bolehkah Semak Data Rujukan Kekangan daripada Jadual Luaran?

Bolehkah Semak Data Rujukan Kekangan daripada Jadual Luaran?

Mary-Kate Olsen
Lepaskan: 2025-01-02 20:24:42
asal
808 orang telah melayarinya

Can Check Constraints Reference Data from External Tables?

Bolehkah Semak Kekangan Menggunakan Data Jadual Luaran?

Dalam bidang pengurusan pangkalan data hubungan, semakan kekangan memainkan peranan penting dalam memastikan integriti data . Kekangan ini menguatkuasakan peraturan khusus pada nilai yang boleh dimasukkan ke dalam jadual. Kes penggunaan biasa ialah mengehadkan nilai dalam julat tertentu atau memastikan ketekalan dengan jadual lain.

Walau bagaimanapun, bolehkah semakan kekangan melampaui rujukan hanya pada jadual yang digunakan? Bolehkah mereka memanfaatkan data daripada jadual lain untuk mentakrifkan sekatan mereka?

Kuasa Semakan CROSS JOIN

Jawapannya ialah ya. Menggunakan semakan silang silang, adalah mungkin untuk mengaitkan kekangan semakan dengan jadual lain. Teknik ini membolehkan anda membuat kekangan yang menguatkuasakan peraturan berdasarkan data daripada pelbagai sumber.

Contoh: Kekangan Semakan Antara Jadual

Pertimbangkan contoh yang diberikan. Kami mempunyai dua jadual:

  • ProjectTimeSpan dengan lajur StartDate dan EndDate.
  • SubProjectTimeS 🎜> dengan lajur Tarikh Mula dan TarikhTamat.
Andaikan kita ingin memastikan bahawa

Tarikh Mula dan Tarikh Tamat sub -jangka masa projek tidak berada di luar nilai yang sepadan dalam jangka masa projek. Kita boleh membuat kekangan semak sambung silang pada SubProjectTimeSpan seperti berikut:

ALTER TABLE SubProjectTimeSpan
ADD CONSTRAINT CK_TimeSpanRange
CHECK (
  EXISTS (
    SELECT *
    FROM ProjectTimeSpan
    WHERE
      StartDate <= SubProjectTimeSpan.StartDate
      AND EndDate >= SubProjectTimeSpan.EndDate
  )
);
Salin selepas log masuk
Semakan ini dengan berkesan menanyakan jadual

ProjectTimeSpan dalam definisi kekangan. Ia memastikan bahawa untuk setiap baris dalam SubProjectTimeSpan, terdapat sekurang-kurangnya satu baris yang sepadan dalam ProjectTimeSpan dengan tarikh mula dan tamat bertindih.

Alternatif dengan Fungsi

Sebagai alternatif, anda boleh gunakan fungsi yang ditentukan pengguna dalam kekangan semakan. Pendekatan ini memberikan fleksibiliti yang lebih besar dan membolehkan anda memasukkan logik kompleks yang merujuk data daripada jadual lain.

Sebagai contoh, fungsi berikut boleh digunakan dalam contoh kami:

CREATE FUNCTION CheckFunction()
RETURNS INT
AS
BEGIN
  RETURN (
    SELECT CASE
      WHEN EXISTS (
        SELECT *
        FROM ProjectTimeSpan
        WHERE
          StartDate <= SubProjectTimeSpan.StartDate
          AND EndDate >= SubProjectTimeSpan.EndDate
      )
      THEN 1
      ELSE 0
    END
  );
END;
Salin selepas log masuk
Kekangan semak kemudiannya boleh digunakan menggunakan fungsi:

ALTER TABLE SubProjectTimeSpan
ADD CONSTRAINT CK_TimeSpanRange
CHECK (CheckFunction() = 1);
Salin selepas log masuk

Kesimpulan

Silang kekangan semak sertaan dan fungsi yang ditentukan pengguna memberi kuasa kepada anda untuk mencipta kekangan yang memanfaatkan data daripada berbilang jadual. Dengan mengeksploitasi teknik ini, anda boleh meningkatkan integriti data dan menguatkuasakan peraturan perniagaan yang kompleks dengan berkesan. Ingat, kemungkinan tidak terhad!

Atas ialah kandungan terperinci Bolehkah Semak Data Rujukan Kekangan daripada Jadual Luaran?. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan