Mysql
 sql >> база данни >  >> RDS >> Mysql

Обработка на изключения на EntityManager в сесиен бийн

Имам предложение, което използвам в приложението си. Можем да извлечем SQLException от PersistenceException . След това опитайте да получите sql error code за SQLException . Ако изискването ви е да получите sql error code , можете да последвате примера ми;

public void insert(Group group) throws DAOException {
    try {
        //your operation
        em.flush();
        logger.debug("insert() method has been successfully finisehd.");
    } catch (PersistenceException pe) {
        String sqlErroCode = getErrorCode(pe);
        // do your operation based on sql errocode
    }
}

protected String getErrorCode(RuntimeException e) {
    Throwable throwable = e;
    while (throwable != null && !(throwable instanceof SQLException)) {
        throwable = throwable.getCause();
    }
    if (throwable instanceof SQLException) {
        Properties properties = --> load sql error code form configuration file.
        SQLException sqlex = (SQLException) throwable;
        String errorCode = properties.getProperty(sqlex.getErrorCode() + "");
        return errorCode;
    }
    return "NONE";
}

Примерна конфигурация на код за грешка на mysql

mysql_error_code.properties

#MySQL Database
1062=DUPLICATE_KEY_FOUND
1216=CHILD_RECORD_FOUND
1217=PARENT_RECORD_NOT_FOUND
1048=NULL_VALUE_FOUND
1205=RECORD_HAS_BEEN_LOCKED 



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Разбиране на структурата на записите на MyISAM

  2. MySQL заявка за намиране на теглото на ръбовете в графика

  3. QueryException в хибернация поради апостроф

  4. MySQL:Оптимизация ГРУПИРА ПО множество клавиши

  5. Как да получите общия брой резултати, когато има LIMIT в заявката?