服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Springboot核心知识点之数据访问配置

Springboot核心知识点之数据访问配置

2021-12-30 22:46Spring源码解读 Java教程

Spring Boot还提供了一个名为DataSourceBuilder的实用工具生成器类,可用于创建一个标准数据源(如果它位于类路径上)。构建器可以根据类路径上的可用内容检测要使用的类。

Springboot核心知识点之数据访问配置

环境:Springboot2.4.13

自定义数据源配置

  1. @Bean 
  2. @ConfigurationProperties(prefix="app.datasource"
  3. public DataSource dataSource() { 
  4.   return new FancyDataSource(); 

配置文件

  1. app: 
  2.   datasource: 
  3.     url: "jdbc:h2:mem:mydb" 
  4.     username: "sa" 
  5.     password"123123" 
  6.     pool-size: 30 

FancyDataSource类具有相应的url,username,pool-size属性。

Spring Boot还提供了一个名为DataSourceBuilder的实用工具生成器类,可用于创建一个标准数据源(如果它位于类路径上)。构建器可以根据类路径上的可用内容检测要使用的类。它还根据JDBCURL自动检测驱动程序。

  1. @Bean 
  2. @ConfigurationProperties("app.datasource"
  3. public DataSource dataSource() { 
  4.   return DataSourceBuilder.create().build(); 

然而,有一个陷阱。因为连接池的实际类型没有提供,所以在自定义数据源的元数据中没有生成任何键,并且IDE中没有可用的完成(因为数据源接口不公开任何属性)。此外,如果类路径上碰巧有Hikari,则此基本设置不起作用,因为Hikari没有url属性(但有jdbcUrl属性)。在这种情况下,你必须按如下方式重写配置:

  1. app: 
  2.   datasource: 
  3.     jdbc-url: "jdbc:mysql://localhost/test" 
  4.     username: "dbuser" 
  5.     password"dbpass" 
  6.     pool-size: 30 

可以强制指定数据源类型

  1. @Bean 
  2. @ConfigurationProperties("app.datasource"
  3. public HikariDataSource dataSource() { 
  4.   return DataSourceBuilder.create().type(HikariDataSource.class).build(); 

多数据源配置

如果需要配置多个数据源,可以应用上一节中描述的相同技巧。但是,你必须将其中一个数据源实例标记为@Primary,因为将来的各种自动配置都希望能够按类型获得一个。

如果您创建自己的数据源,自动配置将退出。在以下示例中,我们提供了与主数据源上的自动配置完全相同的功能集:

  1. @Bean 
  2. @Primary 
  3. @ConfigurationProperties("app.datasource.first"
  4. public DataSourceProperties firstDataSourceProperties() { 
  5.   return new DataSourceProperties(); 
  6.  
  7. @Bean 
  8. @Primary 
  9. @ConfigurationProperties("app.datasource.first.configuration"
  10. public HikariDataSource firstDataSource() { 
  11.   return firstDataSourceProperties().initializeDataSourceBuilder().type(HikariDataSource.class).build(); 
  12.  
  13. @Bean 
  14. @ConfigurationProperties("app.datasource.second"
  15. public BasicDataSource secondDataSource() { 
  16.   return DataSourceBuilder.create().type(BasicDataSource.class).build(); 

这两个数据源还绑定了高级定制。例如,您可以按如下方式配置它们:

  1. app: 
  2.   datasource: 
  3.     first
  4.       url: "jdbc:mysql://localhost/first" 
  5.       username: "dbuser" 
  6.       password"dbpass" 
  7.       configuration: 
  8.         maximum-pool-size: 30 
  9.     second
  10.       url: "jdbc:mysql://localhost/second" 
  11.       username: "dbuser" 
  12.       password"dbpass" 
  13.       max-total: 30 

你也可以将相同的概念应用于辅助数据源,如以下示例所示:

  1. @Bean 
  2. @Primary 
  3. @ConfigurationProperties("app.datasource.first"
  4. public DataSourceProperties firstDataSourceProperties() { 
  5.   return new DataSourceProperties(); 
  6.  
  7. @Bean 
  8. @Primary 
  9. @ConfigurationProperties("app.datasource.first.configuration"
  10. public HikariDataSource firstDataSource() { 
  11.   return firstDataSourceProperties().initializeDataSourceBuilder().type(HikariDataSource.class).build(); 
  12.  
  13. @Bean 
  14. @ConfigurationProperties("app.datasource.second"
  15. public DataSourceProperties secondDataSourceProperties() { 
  16.   return new DataSourceProperties(); 
  17.  
  18. @Bean 
  19. @ConfigurationProperties("app.datasource.second.configuration"
  20. public BasicDataSource secondDataSource() { 
  21.   return secondDataSourceProperties().initializeDataSourceBuilder().type(BasicDataSource.class).build(); 

使用Spring Data Repositories

Spring data 可以创建各种风格的@Repository接口的实现。只要这些@Repositories包含在@EnableAutoConfiguration类的同一个包(或子包)中,Spring Boot就可以为您处理所有这些。

对于许多应用程序,只需将正确的Spring Data依赖项放在类路径上。

spring-boot-starter-data-jpa for JPA, spring-boot-starter-data-mongodb for Mongodb,等等。要开始,请创建一些存储库接口来处理@Entity对象。

Spring Boot根据找到的@EnableAutoConfiguration,尝试猜测@Repository定义的位置。要获得更多控制,请使用@EnableJpaRepositories注释。

将@Entity定义与Spring配置分开

Spring Boot试图根据它找到的@EnableAutoConfiguration猜测@Entity定义的位置。要获得更多控制,可以使用@EntityScan注释,如下例所示:

  1. @Configuration(proxyBeanMethods = false
  2. @EnableAutoConfiguration 
  3. @EntityScan(basePackageClasses=City.class) 
  4. public class Application { 
  5.   //... 

配置JPA属性

Spring Data JPA已经提供了一些独立于供应商的配置选项(如SQL日志记录选项),SpringBoot将这些选项和Hibernate的一些选项公开为外部配置属性。其中一些是根据上下文自动检测的,因此您不必设置它们。

spring.jpa.hibernate.ddl-auto是一种特殊情况,因为根据运行时条件,它有不同的默认值。如果使用嵌入式数据库,并且没有模式管理器(如Liquibase或Flyway)处理数据源,则默认情况下为create-drop。在所有其他情况下,它默认为none。

要使用的方言由JPA提供程序检测。如果您喜欢自己设置方言,请设置

spring.jpa.database-platform属性。

  1. spring: 
  2.   jpa: 
  3.     hibernate: 
  4.       naming: 
  5.         physical-strategy: "com.example.MyPhysicalNamingStrategy" 
  6.     show-sql: true 

配置Hibernate命名策略

Hibernate使用两种不同的命名策略将名称从对象模型映射到相应的数据库名称。可以通过设置

spring.jpa.hibernate.naming.physical-strategy属性,属性值为类的全限定名,package + clalss。

默认情况下,Spring Boot使用

SpringPhysicalNamingStrategy配置物理命名策略。此实现提供了与Hibernate4相同的表结构:所有点都替换为下划线,驼峰大小写也替换为下划线。此外,默认情况下,所有表名都以小写形式生成。例如,电话号码实体映射到电话号码表。如果您的模式需要混合大小写标识符,请定义自定义SpringPhysicalNamingStrategybean,如以下示例所示:

  1. @Bean 
  2. SpringPhysicalNamingStrategy caseSensitivePhysicalNamingStrategy() { 
  3.   return new SpringPhysicalNamingStrategy() { 
  4.     @Override 
  5.     protected boolean isCaseInsensitive(JdbcEnvironment jdbcEnvironment) { 
  6.       return false
  7.     } 
  8.  }; 

如果您更喜欢使用Hibernate 5的默认设置,请设置以下属性:

  1. spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl 

或者,您可以配置以下bean

  1. @Bean 
  2. public PhysicalNamingStrategy physicalNamingStrategy() { 
  3.   return new PhysicalNamingStrategyStandardImpl(); 

配置Hibernat二级缓存

Hibernate二级缓存可以为一系列缓存提供程序进行配置。与其将Hibernate配置为再次查找缓存提供程序,不如尽可能提供上下文中可用的缓存提供程序。

要使用JCache实现这一点,首先要确保

org.hibernate.HibernateJCache在类路径上可用。然后,添加HibernatePropertiesCustomizer bean,如以下示例所示:

  1. @Configuration(proxyBeanMethods = false
  2. public class HibernateSecondLevelCacheExample { 
  3.   @Bean 
  4.   public HibernatePropertiesCustomizer hibernateSecondLevelCacheCustomizer(JCacheCacheManager cacheManager) { 
  5.     return (properties) -> properties.put(ConfigSettings.CACHE_MANAGER, cacheManager.getCacheManager()); 
  6.     } 

使用多个EntityManagerFactories

如果需要对多个数据源使用JPA,那么每个数据源可能需要一个EntityManagerFactory。Spring ORM中的

LocalContainerEntityManagerFactoryBean允许您根据需要配置EntityManagerFactory。您还可以重用JPA属性来绑定每个EntityManagerFactory的设置,如以下示例所示:

  1. @Bean 
  2. @ConfigurationProperties("app.jpa.first"
  3. public JpaProperties firstJpaProperties() { 
  4.   return new JpaProperties(); 
  5.  
  6. @Bean 
  7. public LocalContainerEntityManagerFactoryBean firstEntityManagerFactory(DataSource firstDataSource, JpaProperties firstJpaProperties) { 
  8.   EntityManagerFactoryBuilder builder = createEntityManagerFactoryBuilder(firstJpaProperties); 
  9.   return builder.dataSource(firstDataSource).packages(Order.class).persistenceUnit("firstDs").build(); 
  10.  
  11. private EntityManagerFactoryBuilder createEntityManagerFactoryBuilder(JpaProperties jpaProperties) { 
  12.   JpaVendorAdapter jpaVendorAdapter = createJpaVendorAdapter(jpaProperties); 
  13.   return new EntityManagerFactoryBuilder(jpaVendorAdapter, jpaProperties.getProperties(), null); 
  14.  
  15. private JpaVendorAdapter createJpaVendorAdapter(JpaProperties jpaProperties) { 
  16.   // Map JPA properties as needed 
  17.   return new HibernateJpaVendorAdapter(); 

上面的示例使用名为firstDataSource的数据源bean创建EntityManagerFactory。它扫描与订单位于同一包中的实体。可以使用该应用程序映射其他JPA属性。

将Spring数据存储库公开为REST端点

Spring Data Rest可以将 Repository 实现公开为REST端点,前提是已经为应用程序启用了 SpringMVC。

Spring Boot暴露了一组有用的属性(来自Spring.data.rest命名空间),用于自定义

RepositoryRestConfiguration。如果需要提供额外的定制,那么应该使用RepositoryRestConfiguration。

使用

  1. <dependency> 
  2.   <groupId>org.springframework.boot</groupId> 
  3.   <artifactId>spring-boot-starter-data-rest</artifactId> 
  4. </dependency> 
  5. <dependency> 
  6.   <groupId>org.springframework.data</groupId> 
  7.   <artifactId>spring-data-rest-webmvc</artifactId> 
  8. </dependency> 

原文链接:https://www.toutiao.com/a7041436320136167974/

延伸 · 阅读

精彩推荐
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7482021-02-04
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17