Załóżmy, że używasz SQL Server.
Korzystanie z archiwum internetowego — https://web.archive.org/web/20190120182351/https://blogs.msdn.microsoft.com/tomholl/2007/08/01/mapping-sql-server-errors-to-net -wyjątki-zabawne-sposób/
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);
}
}
}
Sprawa 547 to twój mężczyzna.
AKTUALIZUJ Powyższe jest kodem przykładowym i nie należy go używać. Kliknij link, aby wyjaśnić, dlaczego.