Solon v2.7.5

hibernate-solon-plugin

</> markdown

此插件,由社区成员(凌康、bai)贡献

<dependency>
    <groupId>org.noear</groupId>
    <artifactId>hibernate-solon-plugin</artifactId>
</dependency>

1、描述

数据扩展插件,为 Solon Data 提供基于 hibernate 的框架适配,以提供标准 JPA 支持。

2、强调多数据源支持

  • 强调多数据源的配置。例:demo.db1...,demo.db2...
  • 强调带 name 的 DataSource Bean
  • 强调使用 @Db("name") 的数据源注解

@Db 可注入类型:

支持类型说明
Configuration.class注入配置器。例:@Db("db1") Configuration configuration
EntityManagerFactory注入 EntityManagerFactory (jpa 接口)
SessionFactory注入 SessionFactory (hibernate 接口)

3、使用示例

  • 配置示例
#solon 支持的多数据源
test.db1:
  schema: rock
  jdbcUrl: jdbc:mysql://121.40.62.167:3306/test?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
  driverClassName: com.mysql.cj.jdbc.Driver
  username: bai
  password: root

#db test的hibernate配置
jpa.db1:
  mappings:
    - org.example.entity.*
  properties:
    hibernate:
      hbm2ddl:
        auto: create
      show_sql: true
      format_sql: true
      dialect: org.hibernate.dialect.MySQL8Dialect
      connection:
        isolaction: 4 # 事务隔离级别 4 可重复度
  • 构建数据源
//配置数据源
@Configuration
public class Config {
    //此下的 db1 与 jpa.db1 将对应在起来 //可以用 @Db("db1") 注入会话管理
    //typed=true,表示默认数据源。@Db 可不带名字注入 
    @Bean(name="db1", typed=true)
    public DataSource db1(@Inject("${demo.db1}") HikariDataSource ds) {
        return ds;
    }
}
  • 应用
@Mapping("demo")
@Controller
public class JapController {
    @Db //或 @Db("db1")
    private EntityManagerFactory entityManagerFactory;

    private EntityManager openSession() {
        return entityManagerFactory.createEntityManager();
    }

    //支持 solon 的事务管理
    @Tran
    @Mapping("/t")
    public void t1() {
        HttpEntity entity = new HttpEntity();
        entity.setId(System.currentTimeMillis() + "");

        openSession().persist(entity);

    }

    @Mapping("/t2")
    public Object t2() {
        HttpEntity entity = new HttpEntity();
        entity.setId(System.currentTimeMillis() + "");

        return openSession().find(HttpEntity.class, "1");
    }
}