MongoDB是文档型数据库,可以用于分布式系统,不熟悉。
MongoDB的下载安装:点此
每次使用前要先开启服务,类似redis,建议将bin添加到环境变量,然后将开启服务命令
mongod -dbpath "你的db文件夹地址"
写入一个bat文件,以后双击这个文件开启服务就好了。MongoDB可视化工具推荐robot 3T。
pom依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.20</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
这里lombok是用于自动给实体类生成getter、setter方法等的,使用@Data注解就不用写这些方法了。
lombok的使用:我的做法是将lombok的jar包放在eclipse文件夹主目录下,然后在eclipse.ini配置文件后加上2行:
-Xbootclasspath/a:lombok-1.16.20.jar
-javaagent:lombok-1.16.20.jar
因为只是在pom中添加依赖还不够,会报错。
下面进入代码:
先看下代码结构:
启动类:
//这个注解配合@ConfigurationProperties使用
@EnableConfigurationProperties(MultipleMongoProperties.class)
@SpringBootApplication(exclude = MongoAutoConfiguration.class)
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
配置类:这里是对应2个数据库的表,故对应2种,primary和secondary
@Configuration
public class MultipleMongoConfig {
@Autowired
private MultipleMongoProperties mongoProperties;
@Primary
@Bean(name = PrimaryMongoConfig.MONGO_TEMPLATE)
public MongoTemplate primaryMongoTemplate() throws Exception {
//这里的get方法就是自动生成的
return new MongoTemplate(primaryFactory(this.mongoProperties.getPrimary()));
}
@Bean
@Qualifier(SecondaryMongoConfig.MONGO_TEMPLATE)
public MongoTemplate secondaryMongoTemplate() throws Exception {
return new MongoTemplate(secondaryFactory(this.mongoProperties.getSecondary()));
}
@Bean
@Primary
public MongoDbFactory primaryFactory(MongoProperties mongo) throws Exception {
return new SimpleMongoDbFactory(new MongoClient(mongo.getHost(), mongo.getPort()),
mongo.getDatabase());
}
@Bean
public MongoDbFactory secondaryFactory(MongoProperties mongo) throws Exception {
return new SimpleMongoDbFactory(new MongoClient(mongo.getHost(), mongo.getPort()),
mongo.getDatabase());
}
}
既然这里用到了MultipleMongoProperties,那就看看这个类。
@Data//自动生成set,get等方法
@ConfigurationProperties(prefix = "mongodb")//将配置转成bean
public class MultipleMongoProperties {
private MongoProperties primary = new MongoProperties();
private MongoProperties secondary = new MongoProperties();
}
然后再看看配置文件yml:可以看到上面的注解的前缀是mongodb,这里配置文件下的属性对应上面类中的成员。
mongodb:
primary:
host: localhost
port: 27017
database: test1
secondary:
host: localhost
port: 27017
database: test2
然后看看另一个配置类:本来有2个,一个是primary的,一个是secondary的,因为只是这2个单词的区别,只写一个。
第二个注解的具体作用不太了解,意思应该是对不同包使用不同的模板,不同的模板使用不同的配置,也就是说不同的连接吧。
@Configuration
@EnableMongoRepositories(basePackages = "com.neo.model.repository.primary",
mongoTemplateRef = PrimaryMongoConfig.MONGO_TEMPLATE)
public class PrimaryMongoConfig {
protected static final String MONGO_TEMPLATE = "primaryMongoTemplate";
}
实体类:
@Data
@AllArgsConstructor//lombok自动生成构造器
@NoArgsConstructor
@Document(collection = "first_mongo")
public class PrimaryMongoObject {
@Id
private String id;
private String value;
@Override
public String toString() {
return "PrimaryMongoObject{" + "id='" + id + '\'' + ", value='" + value + '\''
+ '}';
}
}
和对应的接口:这个用法类似于jpa的使用,简化了数据库的操作。
public interface PrimaryRepository extends MongoRepository<PrimaryMongoObject, String> {
}
最后是测试:先开启MongoDB服务,然后运行junit test,查看数据库即可。
@RunWith(SpringRunner.class)
@SpringBootTest
public class MuliDatabaseTest {
@Autowired
private PrimaryRepository primaryRepository;
@Autowired
private SecondaryRepository secondaryRepository;
@Test
public void TestSave() {
System.out.println("************************************************************");
System.out.println("测试开始");
System.out.println("************************************************************");
this.primaryRepository
.save(new PrimaryMongoObject(null, "第一个库的对象"));
this.secondaryRepository
.save(new SecondaryMongoObject(null, "第二个库的对象"));
List<PrimaryMongoObject> primaries = this.primaryRepository.findAll();
for (PrimaryMongoObject primary : primaries) {
System.out.println(primary.toString());
}
List<SecondaryMongoObject> secondaries = this.secondaryRepository.findAll();
for (SecondaryMongoObject secondary : secondaries) {
System.out.println(secondary.toString());
}
System.out.println("************************************************************");
System.out.println("测试完成");
System.out.println("************************************************************");
}
}