本文出自 http://www.ityouknow.com/ html
mongodb是最先热门非关系数据库的之一,使用也比较广泛,通常会用作离线数据分析来使用,放到内网的居多。因为不少公司使用了云服务,服务器默认都开放了外网地址,致使前一阵子大批 MongoDB 因配置漏洞被攻击,数据被删,引发了人们的注意,感兴趣的能够看看这篇文章:场屠戮MongoDB的盛宴反思:超33000个数据库遭遇入侵勒索,同时也说明了不少公司生产中大量使用mongodb。spring
MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是能够应用于各类规模的企业、各个行业以及各种应用程序的开源数据库。基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种。mongodb
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构很是松散,是相似json的bjson格式,所以能够存储比较复杂的数据类型。Mongo最大的特色是他支持的查询语言很是强大,其语法有点相似于面向对象的查询语言,几乎能够实现相似关系数据库单表查询的绝大部分功能,并且还支持对数据创建索引。数据库
传统的关系数据库通常由数据库(database)、表(table)、记录(record)三个层次概念组成,MongoDB是由数据库(database)、集合(collection)、文档对象(document)三个层次组成。MongoDB对于关系型数据库里的表,可是集合中没有列、行和关系概念,这体现了模式自由的特色。json
MongoDB中的一条记录就是一个文档,是一个数据结构,由字段和值对组成。MongoDB文档与JSON对象相似。字段的值有可能包括其它文档、数组以及文档数组。MongoDB支持OS X、Linux及Windows等操做系统,并提供了Python,PHP,Ruby,Java及C++语言的驱动程序,社区中也提供了对Erlang及.NET等平台的驱动程序。数组
MongoDB的适合对大量或者无固定格式的数据进行存储,好比:日志、缓存等。对事物支持较弱,不适用复杂的多文档(多表)的级联查询。文中演示mongodb版本为3.4。缓存
Spring Boot对各类流行的数据源都进行了封装,固然也包括了mongodb,下面给你们介绍如何在spring boot中使用mongodb:springboot
pom包里面添加spring-boot-starter-data-mongodb包引用服务器
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> </dependencies>
spring.data.mongodb.uri=mongodb://name:pass@localhost:27017/test
多个IP集群能够采用如下配置:数据结构
spring.data.mongodb.uri=mongodb://user:pwd@ip1:port1,ip2:port2/database
public class UserEntity implements Serializable { private static final long serialVersionUID = -3258839839160856613L; private Long id; private String userName; private String passWord; //getter、setter省略 }
dao层实现了UserEntity对象的增删改查
@Component public class UserDaoImpl implements UserDao { @Autowired private MongoTemplate mongoTemplate; /** * 建立对象 * @param user */ @Override public void saveUser(UserEntity user) { mongoTemplate.save(user); } /** * 根据用户名查询对象 * @param userName * @return */ @Override public UserEntity findUserByUserName(String userName) { Query query=new Query(Criteria.where("userName").is(userName)); UserEntity user = mongoTemplate.findOne(query , UserEntity.class); return user; } /** * 更新对象 * @param user */ @Override public void updateUser(UserEntity user) { Query query=new Query(Criteria.where("id").is(user.getId())); Update update= new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord()); //更新查询返回结果集的第一条 mongoTemplate.updateFirst(query,update,UserEntity.class); //更新查询返回结果集的全部 // mongoTemplate.updateMulti(query,update,UserEntity.class); } /** * 删除对象 * @param id */ @Override public void deleteUserById(Long id) { Query query=new Query(Criteria.where("id").is(id)); mongoTemplate.remove(query,UserEntity.class); } }
@RunWith(SpringRunner.class) @SpringBootTest public class UserDaoTest { @Autowired private UserDao userDao; @Test public void testSaveUser() throws Exception { UserEntity user=new UserEntity(); user.setId(2l); user.setUserName("小明"); user.setPassWord("fffooo123"); userDao.saveUser(user); } @Test public void findUserByUserName(){ UserEntity user= userDao.findUserByUserName("小明"); System.out.println("user is "+user); } @Test public void updateUser(){ UserEntity user=new UserEntity(); user.setId(2l); user.setUserName("天空"); user.setPassWord("fffxxxx"); userDao.updateUser(user); } @Test public void deleteUserById(){ userDao.deleteUserById(1l); } }
可使用工具mongoVUE工具来链接后直接图形化展现查看,也能够登陆服务器用命令来查看
1.登陆mongos
bin/mongo -host localhost -port 20000
二、切换到test库
use test
三、查询userEntity集合数据
db.userEntity.find()
根据3查询的结果来观察测试用例的执行是否正确。
到此springboot对应mongodb的增删改查功能已经所有实现。
在多mongodb数据源的状况下,咱们换种更优雅的方式来实现
添加lombok和spring-boot-autoconfigure包引用
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-autoconfigure</artifactId> <version>RELEASE</version> </dependency>
Lombok - 是一个能够经过简单的注解形式来帮助咱们简化消除一些必须有但显得很臃肿的Java代码的工具,经过使用对应的注解,能够在编译源码的时候生成对应的方法。简单试了如下这个工具还挺好玩的,加上注解咱们就不用手动写 getter\setter、构建方式相似的代码了。
spring-boot-autoconfigure - 就是spring boot的自动化配置
mongodb: primary: host: 192.168.9.60 port: 20000 database: test secondary: host: 192.168.9.60 port: 20000 database: test1
封装读取以mongodb开头的两个配置文件
@Data @ConfigurationProperties(prefix = "mongodb") public class MultipleMongoProperties { private MongoProperties primary = new MongoProperties(); private MongoProperties secondary = new MongoProperties(); }
配置不一样包路径下使用不一样的数据源
第一个库的封装
@Configuration @EnableMongoRepositories(basePackages = "com.neo.model.repository.primary", mongoTemplateRef = PrimaryMongoConfig.MONGO_TEMPLATE) public class PrimaryMongoConfig { protected static final String MONGO_TEMPLATE = "primaryMongoTemplate"; }
第二个库的封装
@Configuration @EnableMongoRepositories(basePackages = "com.neo.model.repository.secondary", mongoTemplateRef = SecondaryMongoConfig.MONGO_TEMPLATE) public class SecondaryMongoConfig { protected static final String MONGO_TEMPLATE = "secondaryMongoTemplate"; }
读取对应的配置信息而且构造对应的MongoTemplate
@Configuration public class MultipleMongoConfig { @Autowired private MultipleMongoProperties mongoProperties; @Primary @Bean(name = PrimaryMongoConfig.MONGO_TEMPLATE) public MongoTemplate primaryMongoTemplate() throws Exception { 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()); } }
两个库的配置信息已经完成。
借助lombok来构建对象
@Data @AllArgsConstructor @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 + '\'' + '}'; } }
对应的Repository
public interface PrimaryRepository extends MongoRepository<PrimaryMongoObject, String> { }
继承了 MongoRepository 会默认实现不少基本的增删改查,省了不少本身写dao层的代码
Secondary和上面的代码相似就不贴出来了
1 @RunWith(SpringRunner.class) 2 @SpringBootTest 3 public class MuliDatabaseTest { 4 5 @Autowired 6 private PrimaryRepository primaryRepository; 7 8 @Autowired 9 private SecondaryRepository secondaryRepository; 10 11 @Test 12 public void TestSave() { 13 14 System.out.println("************************************************************"); 15 System.out.println("测试开始"); 16 System.out.println("************************************************************"); 17 18 this.primaryRepository 19 .save(new PrimaryMongoObject(null, "第一个库的对象")); 20 21 this.secondaryRepository 22 .save(new SecondaryMongoObject(null, "第二个库的对象")); 23 24 List<PrimaryMongoObject> primaries = this.primaryRepository.findAll(); 25 for (PrimaryMongoObject primary : primaries) { 26 System.out.println(primary.toString()); 27 } 28 29 List<SecondaryMongoObject> secondaries = this.secondaryRepository.findAll(); 30 31 for (SecondaryMongoObject secondary : secondaries) { 32 System.out.println(secondary.toString()); 33 } 34 35 System.out.println("************************************************************"); 36 System.out.println("测试完成"); 37 System.out.println("************************************************************"); 38 } 39 40 }
到此,mongodb多数据源的使用已经完成。