Crear un gestor de errores


<?php
// función de gestión de errores
function miGestorDeErrores($errno, $errstr, $errfile, $errline)
{
    if (!(error_reporting() & $errno)) {
        // Este código de error no está incluido en error_reporting
        return;
    }
 
    switch ($errno) {
    case E_USER_ERROR:
        echo "<b>Mi ERROR</b> [$errno] $errstr<br />\n";
        echo "  Error fatal en la línea $errline en el archivo $errfile";
        echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />\n";
        echo "Abortando...<br />\n";
        exit(1);
        break;
 
    case E_USER_WARNING:
        echo "<b>Mi WARNING</b> [$errno] $errstr<br />\n";
        break;
 
    case E_USER_NOTICE:
        echo "<b>Mi NOTICE</b> [$errno] $errstr<br />\n";
        break;
 
    default:
        echo "Tipo de error desconocido: [$errno] $errstr<br />\n";
        break;
    }
 
    /* No ejecutar el gestor de errores interno de PHP */
    return true;
}?>

Indicar cual es el gestor de errores


set_error_handler("miGestorDeErrores");

Poner un trigger para capturar un error

//throw new Exception
            if (mysql_errno()=='1109')
                trigger_error("TABLENOEXISTS", E_USER_ERROR);                            // Error: Table not exist
            else
                trigger_error(mysql_errno().': '.mysql_error(), E_USER_ERROR);

Ejemplo de respuesta en

**Mi WARNING** [512] Error occured in Execute.Invalid query: Duplicate entry 'pepe2@pepe.com' for key 'email_UNIQUE'