您好,登錄后才能下訂單哦!
這篇文章主要介紹了Spring-boot集成pg、mongo多數據源過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
修改POM文件,增加相應Jar包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> <dependency> <groupId>org.postgresql</groupId> <artifactId>postgresql</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency>
修改啟動類,去除原有的數據源自動加載機制
@SpringBootApplication( exclude = {DataSourceAutoConfiguration.class, PageHelperAutoConfiguration.class , MongoAutoConfiguration.class, MongoDataAutoConfiguration.class//禁用數據源自動配置 }) @EnableEurekaClient public class MainApplication {、、、
編寫application.yml文件,增加配置信息
spring: # 默認的postgreSQL庫 datasource: pg: url: jdbc:postgresql://127.0.0.1:5432/pgdb username: us_wu password: netcool@919 driver-class-name: org.postgresql.Driver mg: host: 127.0.0.1 username: aaa password: aaa database: mgdb port: 27017
分別手動增加PG、mongo的數據源以及使用樣例
pg
1、手動加載數據源
@Configuration public class DataSourceConfig { final String cmspg="spring.datasource.pg"; @Bean(name = "pgDS") @ConfigurationProperties(prefix =pg) public DataSource dataSource() { return DataSourceBuilder.create().build(); }
2、創建pg配置文件,指定SqlSessionFactory以及要掃描的Dao
@Configuration @MapperScan(basePackages = {"com.**.mapper.pg"}, sqlSessionFactoryRef = "sqlSessionFactory") public class PostgresDBConfig { @Autowired @Qualifier("pgDS") private DataSource pgDS; @Bean public SqlSessionFactory sqlSessionFactory() throws Exception { SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean(); factoryBean.setDataSource(pgDS); return factoryBean.getObject(); } @Bean public SqlSessionTemplate sqlSessionTemplate() throws Exception { SqlSessionTemplate template = new SqlSessionTemplate(sqlSessionFactory()); // 使用上面配置的Factory return template; } }
3、編寫Dao--注解形式
@Repository @Mapper public interface StCableFiberMapper { @Select("SELECT * FROM st_cable_fiber WHERE id = #{id}") St_cable_fiber findById(@Param("id") String id);
mongo
1、加載mongo配置信息
public abstract class AbstractMongoConfigure { private String host, database, username, password; private int port; // Setter methods go here.. /* * Method that creates MongoDbFactory Common to both of the MongoDb * connections */ public MongoDbFactory mongoDbFactory() throws Exception { ServerAddress serverAddress = new ServerAddress(host, port); List<MongoCredential> mongoCredentialList = new ArrayList<>(); mongoCredentialList.add(MongoCredential.createScramSha1Credential(username, database, password.toCharArray())); return new SimpleMongoDbFactory(new MongoClient(serverAddress,mongoCredentialList), database); } /* * Factory method to create the MongoTemplate */ abstract public MongoTemplate getMongoTemplate() throws Exception; } @Configuration @EnableMongoRepositories(basePackages = {"com.**.mapper.mg"},mongoTemplateRef = "mongoTemplate") @ComponentScan @ConfigurationProperties(prefix = "spring.datasource.mg") public class MongoMasterConfig extends AbstractMongoConfigure{ @Override @Bean("mongoTemplate") public MongoTemplate getMongoTemplate() throws Exception { return new MongoTemplate(mongoDbFactory()); } }
編寫Dao MongoTemplate模式
@Repository public class CmCableDetailRepo{ @Autowired private MongoTemplate mongoTemplate; public Page<Cm_Cable> findByLevelAndName(String areacode, int level,String name,int pageNum, int pageSize){ PageRequest page = new PageRequest(pageNum, pageSize); Query query = new Query(); Criteria criteria = new Criteria(); criteria.and("areacode").regex("^"+areacode); if(level > -1){ criteria.and("cableSegment_level").is(level); } if(null != name && name.trim().length() > 0){ criteria.and("zh_label").regex(".*?"+name+".*"); } query.addCriteria(criteria); Long count = mongoTemplate.count(query, Cm_Cable.class); List<Cm_Cable> list = mongoTemplate.find(query.with(page), Cm_Cable.class); return new PageImpl<Cm_Cable>(list, page, count); }
MongoRepository模式
@Repository public interface CmCableDetailMapper extends MongoRepository<Cm_Cable, String>{ }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。