spring-orm:6 HibernateJpaVendorAdapter源码解析

版本

spring-orm:6.1.3

源码

org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter

java 复制代码
public class HibernateJpaVendorAdapter extends AbstractJpaVendorAdapter {
	// 旧版本Hibernate的方言类是否存在标识
	private static final boolean oldDialectsPresent = ClassUtils.isPresent(
			"org.hibernate.dialect.PostgreSQL95Dialect", HibernateJpaVendorAdapter.class.getClassLoader());
	// jpa方言
	private final HibernateJpaDialect jpaDialect = new HibernateJpaDialect();
	...
	// 构建Jpa属性
	private Map<String, Object> buildJpaPropertyMap(boolean connectionReleaseOnClose) {
		Map<String, Object> jpaProperties = new HashMap<>();
		// 从 spring.jpa.database-platform 属性获取方言类名
		if (getDatabasePlatform() != null) {
			jpaProperties.put(AvailableSettings.DIALECT, getDatabasePlatform());
		}
		else {
			// 根据 spring.jpa.database 属性获取方言类
			Class<?> databaseDialectClass = determineDatabaseDialectClass(getDatabase());
			if (databaseDialectClass != null) {
				jpaProperties.put(AvailableSettings.DIALECT, databaseDialectClass.getName());
			}
		}
		// 如果设置了 spring.jpa.generate-ddl=true 则设置 hibernate.hbm2ddl.auto=update
		if (isGenerateDdl()) {
			jpaProperties.put(AvailableSettings.HBM2DDL_AUTO, "update");
		}
		// 如果设置了 spring.jpa.show-sql=true, 则设置 hibernate.show_sql=true
		if (isShowSql()) {
			jpaProperties.put(AvailableSettings.SHOW_SQL, "true");
		}
		// 如果需要在关闭会话时释放连接, 则设置 hibernate.connection.handling_mode=DELAYED_ACQUISITION_AND_HOLD (延迟获取,关闭会话时释放连接)
		if (connectionReleaseOnClose) {
			jpaProperties.put(AvailableSettings.CONNECTION_HANDLING,
					PhysicalConnectionHandlingMode.DELAYED_ACQUISITION_AND_HOLD);
		}

		// For SpringBeanContainer to be called on Hibernate 6.2
		jpaProperties.put("hibernate.cdi.extensions", "true");

		return jpaProperties;
	}
	
	// 根据数据库类型决定方言类
	protected Class<?> determineDatabaseDialectClass(Database database) {
		// 根据旧版本Hibernate的方言类是否存在判断Hibernate版本
		if (oldDialectsPresent) {  // Hibernate版本低于6.2
			return switch (database) {
				case DB2 -> DB2Dialect.class;
				case DERBY -> DerbyTenSevenDialect.class;
				case H2 -> H2Dialect.class;
				case HANA -> HANAColumnStoreDialect.class;
				case HSQL -> HSQLDialect.class;
				case INFORMIX -> Informix10Dialect.class;
				case MYSQL -> MySQL57Dialect.class;
				case ORACLE -> Oracle12cDialect.class;
				case POSTGRESQL -> PostgreSQL95Dialect.class;
				case SQL_SERVER -> SQLServer2012Dialect.class;
				case SYBASE -> SybaseDialect.class;
				default -> null;
			};
		}
		else {  // Hibernate版本高于6.2(包含)
			return switch (database) {
				case DB2 -> DB2Dialect.class;
				case DERBY -> org.hibernate.dialect.DerbyDialect.class;
				case H2 -> H2Dialect.class;
				case HANA -> HANAColumnStoreDialect.class;
				case HSQL -> HSQLDialect.class;
				case MYSQL -> MySQLDialect.class;
				case ORACLE -> OracleDialect.class;
				case POSTGRESQL -> org.hibernate.dialect.PostgreSQLDialect.class;
				case SQL_SERVER -> SQLServerDialect.class;
				case SYBASE -> SybaseDialect.class;
				default -> null;
			};
		}
	}
相关推荐
千寻技术帮18 小时前
10356_基于Springboot的老年人管理系统
java·spring boot·后端·vue·老年人
最贪吃的虎18 小时前
Redis 除了缓存,还能干什么?
java·数据库·redis·后端·缓存
崎岖Qiu18 小时前
【设计模式笔记24】:JDK源码分析-Comparator中的「策略模式」
java·笔记·设计模式·jdk·策略模式
萧曵 丶18 小时前
Java 安全的单例模式详解
java·开发语言·单例模式
Qiuner18 小时前
Spring Boot 全局异常处理策略设计(一):异常不只是 try-catch
java·spring boot·后端
superman超哥18 小时前
Rust 错误处理模式:Result、?运算符与 anyhow 的最佳实践
开发语言·后端·rust·运算符·anyhow·rust 错误处理
强子感冒了18 小时前
Java List学习笔记:ArrayList与LinkedList的实现源码分析
java·笔记·学习
微爱帮监所写信寄信18 小时前
微爱帮监狱寄信写信小程序PHP底层优化框架
java·开发语言·数据库·spring·微信·php·mybatis
MoonPointer-Byte18 小时前
MoonReader:基于 SpringBoot 3.4 & React 的沉浸式协作阅读平台
spring boot·后端·react.js
琥珀.18 小时前
查看linux下java服务进程是否正常
java·linux·运维