Abstracción anormal de Spring-Notas de estudio de entrada de Spring 06

Notas de estudio @ 玩转 Spring 全家 斗

El contenido del curso proviene del tiempo geek jugando Spring Family Bucket, invadido y eliminado , el enlace es el siguiente
https://time.geekbang.org/course/intro/100023501

Cuarto día

La abstracción anormal de Spring

DataAccessException

Spring convertirá las excepciones de operaciones de datos en DataAccessExceptions,
sin importar qué método de acceso a datos se utilice, se pueden utilizar las mismas excepciones

¿Cómo reconoce Spring esos códigos de error?
Analice los códigos de error a través de la clase SQLErrorCodeSQLExceptionTranslator
y defina el ErrorCode de cada base de datos en ella

• org / springframework / jdbc / support / sql-error-codes.xml
• Classpath 下 的 sql-error-codes.x

Código de
muestra : archivo /resources/sql-error-codes.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN 2.0//EN" "http://www.springframework.org/dtd/spring-beans-2.0.dtd">

<beans>

    <bean id="H2" class="org.springframework.jdbc.support.SQLErrorCodes">
        <property name="badSqlGrammarCodes">
            <value>42000,42001,42101,42102,42111,42112,42121,42122,42132</value>
        </property>
        <property name="duplicateKeyCodes">
            <value>23001,23505</value>
        </property>
        <property name="dataIntegrityViolationCodes">
            <value>22001,22003,22012,22018,22025,23000,23002,23003,23502,23503,23506,23507,23513</value>
        </property>
        <property name="dataAccessResourceFailureCodes">
            <value>90046,90100,90117,90121,90126</value>
        </property>
        <property name="cannotAcquireLockCodes">
            <value>50200</value>
        </property>
        <property name="customTranslations">
            <bean class="org.springframework.jdbc.support.CustomSQLErrorCodesTranslation">
                <property name="errorCodes" value="23001,23505" />
                <property name="exceptionClass"
                          value="geektime.spring.data.errorcodedemo.CustomDuplicatedKeyException" />
            </bean>
        </property>
    </bean>

</beans>

Clase de excepción DuplicateKeyException

package geektime.spring.data.errorcodedemo;

import org.springframework.dao.DuplicateKeyException;

public class CustomDuplicatedKeyException extends DuplicateKeyException {
    
    
    public CustomDuplicatedKeyException(String msg) {
    
    
        super(msg);
    }

    public CustomDuplicatedKeyException(String msg, Throwable cause) {
    
    
        super(msg, cause);
    }
}

Clase de prueba ErrorCodeDemoApplicationTests

package geektime.spring.data.errorcodedemo;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.test.context.junit4.SpringRunner;

@RunWith(SpringRunner.class)
@SpringBootTest
public class ErrorCodeDemoApplicationTests {
    
    
	@Autowired
	private JdbcTemplate jdbcTemplate;

	@Test(expected = CustomDuplicatedKeyException.class)
	public void testThrowingCustomException() {
    
    
		jdbcTemplate.execute("INSERT INTO FOO (ID, BAR) VALUES (1, 'a')");
		jdbcTemplate.execute("INSERT INTO FOO (ID, BAR) VALUES (1, 'b')");
	}
}

Puede ver que en la clase de prueba, la excepción deseada es la clase DuplicateKeyException, y el resultado se pasa.
Inserte la descripción de la imagen aquí
Siempre que la excepción lanzada sea una subclase de DataAccessException, de lo contrario, Spring informará un error y no podrá lanzar una excepción.

Supongo que te gusta

Origin blog.csdn.net/weixin_43596589/article/details/112608441
Recomendado
Clasificación