Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

INSERIRE VALORI DOVE NON ESISTE

Puoi farlo usando un IF dichiarazione:

IF NOT EXISTS 
    (   SELECT  1
        FROM    tblSoftwareTitles 
        WHERE   Softwarename = @SoftwareName 
        AND     SoftwareSystemType = @Softwaretype
    )
    BEGIN
        INSERT tblSoftwareTitles (SoftwareName, SoftwareSystemType) 
        VALUES (@SoftwareName, @SoftwareType) 
    END;

Potresti farlo senza IF usando SELECT

INSERT  tblSoftwareTitles (SoftwareName, SoftwareSystemType) 
SELECT  @SoftwareName,@SoftwareType
WHERE   NOT EXISTS 
        (   SELECT  1
            FROM    tblSoftwareTitles 
            WHERE   Softwarename = @SoftwareName 
            AND     SoftwareSystemType = @Softwaretype
        );

Entrambi i metodi sono suscettibili a una race condition, quindi anche se userei ancora uno dei precedenti per l'inserimento, ma puoi salvaguardare gli inserti duplicati con un vincolo univoco:

CREATE UNIQUE NONCLUSTERED INDEX UQ_tblSoftwareTitles_Softwarename_SoftwareSystemType
    ON tblSoftwareTitles (SoftwareName, SoftwareSystemType);

Esempio su SQL-Fiddle

APPENDICE

In SQL Server 2008 o versioni successive puoi utilizzare MERGE con HOLDLOCK per rimuovere la possibilità di una race condition (che non sostituisce ancora un vincolo univoco).

MERGE tblSoftwareTitles WITH (HOLDLOCK) AS t
USING (VALUES (@SoftwareName, @SoftwareType)) AS s (SoftwareName, SoftwareSystemType) 
    ON s.Softwarename = t.SoftwareName 
    AND s.SoftwareSystemType = t.SoftwareSystemType
WHEN NOT MATCHED BY TARGET THEN 
    INSERT (SoftwareName, SoftwareSystemType) 
    VALUES (s.SoftwareName, s.SoftwareSystemType);

Esempio di unione su SQL Fiddle