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

网站顶部小图标怎么做网站域名管理怎么登陆

网站顶部小图标怎么做,网站域名管理怎么登陆,wordpress文章导入 id,重庆企业网站spring-data-jpa Alibaba Druid多数据源案例 很多情况下,应用需要连接多个数据库,基于此场景,我介绍如何使用spring-data-jpa Alibaba Druid配置多数据源。⚠️ 代码量有点大,请耐心假设一个场景数据库表服务器IP占用端口testor…

spring-data-jpa + Alibaba Druid多数据源案例

很多情况下,应用需要连接多个数据库,基于此场景,我介绍如何使用spring-data-jpa + Alibaba Druid配置多数据源。

⚠️
代码量有点大,请耐心

假设一个场景

数据库服务器IP占用端口
testorders(订单表)192.168.10.313306
demodetail(详情表)192.168.10.323306
trainusers(用户表)192.168.10.333306

pom.xml引入

<!--连接池-->
<dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.8</version>
</dependency>
<!--数据库驱动-->
<dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope>
</dependency>
<!--spring data jpa-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

application.yaml配置

server:port: 8080
spring:datasource:ds1:url: jdbc:mysql://192.168.10.31:3306/testusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driverds2:url: jdbc:mysql://192.168.10.33:3306/trainusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driverds3:url: jdbc:mysql://192.168.10.32:3306/demousername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driver

DataSource配置

为了让spring-data-jpa分别使用这三个库,那么我们需要配置3个datasource

package cn.train.springdruid.config.datasource;import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;import javax.sql.DataSource;
/*** 多数据源配置* */
@Configuration
public class DataSourcesConfig {@Bean(name = {"ds1"})@Primary@ConfigurationProperties(prefix = "spring.datasource.ds1")public DataSource ds1() {DruidDataSource dataSource = DruidDataSourceBuilder.create().build();return dataSource;}@Bean(name = {"ds2"})@ConfigurationProperties(prefix = "spring.datasource.ds2")public DataSource ds2() {DruidDataSource dataSource = DruidDataSourceBuilder.create().build();return dataSource;}@Bean(name = {"ds3"})@ConfigurationProperties(prefix = "spring.datasource.ds3")public DataSource ds3() {DruidDataSource dataSource = DruidDataSourceBuilder.create().build();return dataSource;}
}

JPA配置

接下来针对每个datasource做单独的JPA配置

ds1的JPA配置

package cn.train.springdruid.config.datasource;import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.JpaVendorAdapter;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.transaction.PlatformTransactionManager;import javax.persistence.EntityManagerFactory;
import javax.sql.DataSource;
import java.util.Properties;@Configuration(value = "ds1JPAConfig")
@EnableJpaRepositories(basePackages = "cn.train.springdruid.repositories.ds1",//repository包位置entityManagerFactoryRef = "ds1EntityManagerFactory",transactionManagerRef = "ds1TransactionManager"
)
public class Ds1JPAConfig {@Bean(name = {"ds1TransactionManager"})public PlatformTransactionManager ds1TransactionManager(@Qualifier("ds1EntityManagerFactory") EntityManagerFactory emf){return new JpaTransactionManager(emf);}@Bean(name = {"ds1EntityManagerFactory"})@Primarypublic LocalContainerEntityManagerFactoryBean ds1EntityManagerFactory(@Qualifier(value = "ds1") DataSource dataSource,JpaVendorAdapter vendorAdapter) {LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();entityManagerFactoryBean.setDataSource(dataSource);entityManagerFactoryBean.setJpaVendorAdapter(vendorAdapter);entityManagerFactoryBean.setPackagesToScan("cn.train.springdruid.entities.ds1");// entity包位置entityManagerFactoryBean.setJpaProperties(new Properties(){{put("hibernate.hbm2ddl.auto", "update");put("hibernate.show_sql", "true");put("hibernate.format_sql", "true");}});return entityManagerFactoryBean;}
}

ds2的JPA配置

package cn.train.springdruid.config.datasource;import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.JpaVendorAdapter;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.transaction.PlatformTransactionManager;import javax.persistence.EntityManagerFactory;
import javax.sql.DataSource;
import java.util.Properties;@Configuration(value = "ds2JPAConfig")
@EnableJpaRepositories(basePackages = "cn.train.springdruid.repositories.ds2",//repository包位置entityManagerFactoryRef = "ds2EntityManagerFactory",transactionManagerRef = "ds2TransactionManager"
)
public class Ds2JPAConfig {@Bean(name = {"ds2TransactionManager"})public PlatformTransactionManager ds2TransactionManager(@Qualifier("ds2EntityManagerFactory") EntityManagerFactory emf){return new JpaTransactionManager(emf);}@Bean(name = {"ds2EntityManagerFactory"})public LocalContainerEntityManagerFactoryBean ds2EntityManagerFactory(@Qualifier(value = "ds2") DataSource dataSource,JpaVendorAdapter vendorAdapter) {LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();entityManagerFactoryBean.setDataSource(dataSource);entityManagerFactoryBean.setJpaVendorAdapter(vendorAdapter);entityManagerFactoryBean.setPackagesToScan("cn.train.springdruid.entities.ds2");// entity包位置entityManagerFactoryBean.setJpaProperties(new Properties(){{put("hibernate.hbm2ddl.auto", "update");put("hibernate.show_sql", "true");put("hibernate.format_sql", "true");}});return entityManagerFactoryBean;}
}

ds3的JPA配置

package cn.train.springdruid.config.datasource;import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.JpaVendorAdapter;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.transaction.PlatformTransactionManager;import javax.persistence.EntityManagerFactory;
import javax.sql.DataSource;
import java.util.Properties;@Configuration(value = "ds3JPAConfig")
@EnableJpaRepositories(basePackages = "cn.train.springdruid.repositories.ds3",//repository包位置entityManagerFactoryRef = "ds3EntityManagerFactory",transactionManagerRef = "ds3TransactionManager"
)
public class Ds3JPAConfig {@Bean(name = {"ds3TransactionManager"})public PlatformTransactionManager ds3TransactionManager(@Qualifier("ds3EntityManagerFactory") EntityManagerFactory emf){return new JpaTransactionManager(emf);}@Bean(name = {"ds3EntityManagerFactory"})public LocalContainerEntityManagerFactoryBean ds3EntityManagerFactory(@Qualifier(value = "ds3") DataSource dataSource,JpaVendorAdapter vendorAdapter) {LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();entityManagerFactoryBean.setDataSource(dataSource);entityManagerFactoryBean.setJpaVendorAdapter(vendorAdapter);entityManagerFactoryBean.setPackagesToScan("cn.train.springdruid.entities.ds3");// entity包位置entityManagerFactoryBean.setJpaProperties(new Properties(){{put("hibernate.hbm2ddl.auto", "update");put("hibernate.show_sql", "true");put("hibernate.format_sql", "true");}});return entityManagerFactoryBean;}
}

ds1的repository包为:cn.train.springdruid.repositories.ds1,其中是OrderRepository


import cn.train.springdruid.entities.ds1.Order;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository(value = "orderRepository")
public interface OrderRepository extends JpaRepository<Order, Long> {
}

ds2的repository包为:cn.train.springdruid.repositories.ds2,其中是UserRepository

package cn.train.springdruid.repositories.ds2;import cn.train.springdruid.entities.ds2.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository(value = "userRepository")
public interface UserRepository extends JpaRepository<User, Long> {
}

ds3的repository包为:cn.train.springdruid.repositories.ds3,其中是DetailRepository

package cn.train.springdruid.repositories.ds3;import cn.train.springdruid.entities.ds3.Detail;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository(value = "detailRepository")
public interface DetailRepository extends JpaRepository<Detail, Long> {
}

entity

ds1的entity包为:cn.train.springdruid.entities.ds1,其中是Order

package cn.train.springdruid.entities.ds1;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import javax.persistence.*;@Data
@NoArgsConstructor
@AllArgsConstructor
@Entity
@Table(name = "orders")
public class Order {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;@Column(name = "order_name")private String name;@Column(name = "order_price")private Integer price;
}

ds2的entity包为:cn.train.springdruid.entities.ds2,其中是:User

package cn.train.springdruid.entities.ds2;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import javax.persistence.*;@Data
@NoArgsConstructor
@AllArgsConstructor
@Entity
@Table(name = "users")
public class User {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;@Column(name = "user_name")private String name;@Column(name = "user_age")private Integer age;
}

ds3的entity包为:cn.train.springdruid.entities.ds3,其中是:Detail

package cn.train.springdruid.entities.ds3;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import javax.persistence.*;@Data
@NoArgsConstructor
@AllArgsConstructor
@Entity
@Table(name = "detail")
public class Detail {@Id@GeneratedValue(strategy = GenerationType.SEQUENCE)private Long id;@Column(name = "description")private String description;
}

由此,就是整个多数据源配置与管理的全部核心代码

http://www.dtcms.com/a/441197.html

相关文章:

  • 网站建设项目策划书格式网络策划员
  • asp.net 发布网站 ftp沙井做网站公司
  • 建设项目验收公示网站个人网站可以备案几个
  • 虚拟机做实验的网站jk网站建设
  • 怎么选择企业建站公司典型的电子商务网站
  • 毕业设计网站设计如何用pageadmin做网站
  • 淘宝客怎样建设网站智慧旅游网站建设方案ppt模板
  • 没有防盗链的网站无锡信息网站建设
  • 金融网站设计方向网站空间 阿里云
  • 医疗网站搭建网站建设业务员转换大
  • 沈阳手机网站开发网站建设毕业设计中期检查
  • 企业3合1网站建设知名网站建设代理
  • 网站还没建设好可以备案吗WordPress授权站资源网
  • 聊城做网站的公司行情东阳住房和城市建设网站
  • 工业信息化部网站备案查询网站建设的想法
  • wordpress调用排序从大到小seo咨询师
  • 司局网站维护廉政风险建设长治做百度网站一年多少钱
  • 王欣网站建设与维护上海商地网站建设公司
  • 网站网站开发者犯法吗html登录注册页面代码
  • 一般做网站要多少钱.ai域名注册网站
  • 拍拍网站源码网站设计制作开发公司
  • 网站域名com和cn的差别在哪里加工订单网
  • 网站怎么做动态切图连云港seo
  • 昆明做网站找启搜网络wordpress导航栏透明
  • 哪个网站是做韩国化妆品正品市场营销模式有哪些
  • 专业单位网站设计企业58同城类似的网站怎么做
  • 天津seo网站管理抖音代运营方案计划书
  • php众筹网站程序源码静态网站建设的主要技术
  • 邢台建站详情页设计 制作
  • 网站建设数据库怎么传送优秀的网页网站设计