Heim > Datenbank > MySQL-Tutorial > Wie kann ich Unterabfragen in SQL Server-Prüfeinschränkungen verwenden?

Wie kann ich Unterabfragen in SQL Server-Prüfeinschränkungen verwenden?

Patricia Arquette
Freigeben: 2025-01-04 18:31:40
Original
335 Leute haben es durchsucht

How Can I Use Subqueries in SQL Server Check Constraints?

Unterabfragen in Prüfeinschränkungen verwenden

In SQL Server 2008 R2 wird versucht, eine Prüfeinschränkung mit einer Unterabfrage zu definieren, z. B.:

ALTER TABLE Table1
WITH CHECK ADD CONSTRAINT CK_Code
CHECK (MyField in (Select Field From Table2))
Nach dem Login kopieren

führt zu einem Fehler, der darauf hinweist, dass Unterabfragen hier nicht zulässig sind Kontext.

Alternative Lösung: Skalarfunktion

Um diese Validierung ohne Trigger zu erreichen, kann eine Skalarfunktion erstellt und innerhalb der Prüfeinschränkung verwendet werden, die die Unterabfrage kapselt. Hier ist ein Beispiel:

CREATE FUNCTION myFunction(
    @field DATATYPE(?)
)
RETURNS VARCHAR(5)
AS
BEGIN
    IF EXISTS (SELECT * FROM Table2 WHERE MYFIELD = @field)
        RETURN 'True'
    RETURN 'False'
END
Nach dem Login kopieren

Anwenden der Funktion auf die Check-Einschränkung

Sobald die Funktion definiert ist, kann sie wie folgt in der Check-Einschränkung verwendet werden:

ALTER TABLE Table1
WITH CHECK ADD CONSTRAINT CK_Code
CHECK (myFunction(MYFIELD) = 'True')
Nach dem Login kopieren

Durch die Prüfung des von der Funktion zurückgegebenen Skalarwerts anhand einer bestimmten Zeichenfolge (z. B. „True“) wird die gewünschte Validierung erzwungen, ohne dass eine erforderlich ist Unterabfrage direkt im Check-Constraint.

Das obige ist der detaillierte Inhalt vonWie kann ich Unterabfragen in SQL Server-Prüfeinschränkungen verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage