Creare vincoli check

Si applica a: SQL ServerDatabase SQL di AzureIstanza gestita di SQL Azure

È possibile creare un vincolo check in una tabella per specificare i valori di dati accettabili in una o più colonne in SQL Server usando SQL Server Management Studio o Transact-SQL. Per altre informazioni sull'aggiunta di vincoli di colonna, vedere ALTER TABLE column_constraint.

Per altre informazioni, vedere Vincoli univoci e vincoli check.

Osservazioni:

Per eseguire query sui vincoli check esistenti, usare la vista del catalogo di sistema sys.check_constraints.

Autorizzazioni

È richiesta l’autorizzazione ALTER per la tabella.

Usare SQL Server Management Studio

  1. In Esplora oggettiespandere la tabella a cui aggiungere un vincolo check, fare clic con il pulsante destro del mouse su Vincoli e scegliere Nuovo vincolo.

  2. Nella finestra di dialogo Vincoli CHECK selezionare il campo Espressione e quindi sui puntini di sospensione (...).

  3. Nella finestra di dialogo Espressione vincolo CHECK immettere le espressioni SQL per il vincolo CHECK: Ad esempio per limitare le voci nella colonna SellEndDate della tabella Product a un valore che è maggiore o uguale alla data nella colonna SellStartDateo è un valore NULL, digitare:

    SellEndDate >= SellStartDate
    

    In alternativa, per richiedere l'immissione di un valore composto da 5 cifre nella colonna zip, digitare:

    zip LIKE '[0-9][0-9][0-9][0-9][0-9]'
    

    Nota

    Tutti i valori di vincolo non numerici devono essere racchiusi tra virgolette singole (').

  4. Seleziona OK.

  5. Nella categoria Identità è possibile modificare il nome del vincolo CHECK e aggiungere una descrizione (proprietà estesa) per il vincolo.

  6. Nella categoria Progettazione tabelle è possibile impostare quando deve essere applicato il vincolo.

    Azione Selezionare Yes per le seguenti opzioni
    Testare il vincolo su dati che esistevano prima di creare il vincolo Verificare i dati esistenti durante la creazione o l'abilitazione
    Applicare il vincolo quando si verifica un'operazione di replica su questa tabella Applicare per replica
    Applicare il vincolo ogni qualvolta una riga di questa tabella viene inserita o viene aggiornata Attiva per istruzioni INSERTs e UPDATEs
  7. Selezionare Chiudi.

Usare Transact-SQL

  1. In Esplora oggetti connettersi a un'istanza del motore di database.

  2. Sulla barra Standard selezionare Nuova query.

  3. Copiare e incollare l'esempio seguente nella finestra di query e selezionare Esegui.

    Creare prima di tutto il vincolo.

    ALTER TABLE dbo.DocExc
    ADD ColumnD INT NULL CONSTRAINT CHK_ColumnD_DocExc CHECK (
        ColumnD > 10
        AND ColumnD < 50
    );
    GO
    

    Per testare il vincolo, aggiungere prima i valori che passeranno il vincolo check.

    INSERT INTO dbo.DocExc (ColumnD) VALUES (49);
    

    Successivamente, tentare di aggiungere valori che non passeranno il vincolo check.

    INSERT INTO dbo.DocExc (ColumnD) VALUES (55);