sql >> Databáze >  >> RDS >> Sqlserver

Jak mohu vědět, zda byla vyvolána výjimka SQL z důvodu porušení cizího klíče?

Předpokládejme, že používáte SQL Server.

Použití webového archivu - https://web.archive.org/web/20190120182351/https://blogs.msdn.microsoft.com/tomholl/2007/08/01/mapping-sql-server-errors-to-net -exceptions-the-fun-way/

try
{
    # SQL Stuff
}
catch (SqlException ex)
{
    if (ex.Errors.Count > 0) // Assume the interesting stuff is in the first error
    {
        switch (ex.Errors[0].Number)
        {
            case 547: // Foreign Key violation
                throw new InvalidOperationException("Some helpful description", ex);
                break;
            case 2601: // Primary key violation
                throw new DuplicateRecordException("Some other helpful description", ex);
                break;
            default:
                throw new DataAccessException(ex);
        }
    }

}

Případ 547 je váš muž.

AKTUALIZACE Výše uvedený kód je ukázkový a neměl by se používat. Klikněte prosím na odkaz a vysvětlete proč.



  1. Pomocí NEWSEQUENTIALID() vytvořte na serveru SQL Server zvyšující se identifikátor GUID

  2. Dotaz na kontingenční tabulku MySQL s dynamickými sloupci

  3. Ušetřete čas spouštěním sestav Microsoft Access pomocí filtrů v zobrazení rozvržení

  4. Může se aplikace pro Android připojit přímo k online databázi mysql