J'ai trouvé la solution suivante :
-
Étendez le dialecte Hibernate MySQL5 existant :
public class MySQL5Dialect extends org.hibernate.dialect.MySQL5Dialect { /** * Pattern to extract violated constraint name from {@link SQLException}. */ private static final Pattern PATTERN = Pattern.compile(".*constraint\\W+(\\w+).*", Pattern.CASE_INSENSITIVE); private ViolatedConstraintNameExtracter constraintNameExtracter; public MySQL5Dialect() { constraintNameExtracter = new ConstraintNameExtractor(); } @Override public ViolatedConstraintNameExtracter getViolatedConstraintNameExtracter() { return constraintNameExtracter; } private class ConstraintNameExtractor implements ViolatedConstraintNameExtracter { @Override public String extractConstraintName(SQLException sqle) { final String msg = sqle.getMessage(); final Matcher matcher = PATTERN.matcher(msg); String constraintName = null; if (matcher.matches()) { constraintName = matcher.group(1); } return constraintName; } } }
-
Spécifiez le dialecte nouvellement créé dans le fichier de configuration d'Hibernate (hibernate.cfg.xml) :
<property name="dialect">your.package.MySQL5Dialect</property>
-
Maintenant, getConstraintName() renverra le nom réel de la contrainte violée :
try { ... } catch (ConstraintViolationException e) { LOG.error(String.format("Constraint=%s, code=%d", e.getConstraintName(), e.getErrorCode())); }