当前位置: 首页 > news >正文

spring-orm:6 HibernateJpaVendorAdapter源码解析

版本

spring-orm:6.1.3

源码

org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter

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=updateif (isGenerateDdl()) {jpaProperties.put(AvailableSettings.HBM2DDL_AUTO, "update");}// 如果设置了 spring.jpa.show-sql=true, 则设置 hibernate.show_sql=trueif (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.2jpaProperties.put("hibernate.cdi.extensions", "true");return jpaProperties;}// 根据数据库类型决定方言类protected Class<?> determineDatabaseDialectClass(Database database) {// 根据旧版本Hibernate的方言类是否存在判断Hibernate版本if (oldDialectsPresent) {  // Hibernate版本低于6.2return 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;};}}
http://www.lryc.cn/news/302968.html

相关文章:

  • php捕获Fatal error错误与异常处理
  • PyCharm 调试过程中控制台 (Console) 窗口内运行命令 - 实时获取中间状态
  • MacBook Pro如何安装rust编程环境
  • SparkUI任务启动参数介绍(148个参数)
  • nginx 安装
  • 手撕扩散模型(一)| 训练部分——前向扩散,反向预测代码全解析
  • linux 防火墙
  • Go应用性能分析实战
  • MySQL的索引类型
  • picker选择器-年月日选择
  • 【LeetCode-494】目标和(回溯动归)
  • 力扣 188. 买卖股票的最佳时机 IV
  • 【Go语言】Go项目工程管理
  • 美容小程序:让预约更简单,服务更贴心
  • 【递归】:原理、应用与案例解析 ,助你深入理解递归核心思想
  • 【 Maven 】花式玩法之多模块项目
  • LeetCode 热题 100 Day01
  • [vscode]vue js部分结尾加分号
  • 友点CMS image_upload.php 文件上传漏洞复现
  • C语言—指针(3)
  • 【八股文】面向对象基础
  • Day49 647 回文子串 516 最长回文子序列
  • 探秘GNU/Linux Shell:命令行的魔法世界
  • 基于STM32F407的coreJSON使用教程
  • keepalived双主模式测试
  • 微服务中的熔断、降级和限流
  • 2023年便宜的云服务器分享:最低26元4核16G
  • 汽车零部件制造业MES系统解决方案
  • 区块链/加密币/敏感/特殊题材专供外媒发稿,英文多国语言海外新闻营销推广
  • 初识Nginx