详解MongoDB和Spring整合的实例代码
详解MongoDB和Spring整合的实例代码
MongoDB现在用的非常非常多,如何和Spring整合也是经常碰到的问题。
Spring提供了MongoTemplate这样一个模板类的实现方法,简化了具体操作。
下面讲一下具体实现:
添加依赖
其余Spring相关的忽略
Spring的配置applicationContext-mongo.xml
xmlns:util="http://springframework.org/schema/util" xmlns:xsi="http://w3.org/2001/XMLSchema-instance" xmlns:context="http://springframework.org/schema/context" xmlns:mongo="http://springframework.org/schema/data/mongo" xsi:schemaLocation=" http://springframework.org/schema/util http://springframework.org/schema/util/spring-util.xsd http://springframework.org/schema/beans http://springframework.org/schema/beans/spring-beans.xsd http://springframework.org/schema/context http://springframework.org/schema/context/spring-context.xsd http://springframework.org/schema/data/mongo http://springframework.org/schema/data/mongo/sprihttp://ng-mongo.xsd"> ignore-unresolvable="true" location="classpath:/mongodb.properties"/> dbname="${mongo.database}" mongo-ref="mongoClient"/> type-mapper-ref="defaultMongoTypeMapper">
xmlns:util="http://springframework.org/schema/util"
xmlns:xsi="http://w3.org/2001/XMLSchema-instance"
xmlns:context="http://springframework.org/schema/context"
xmlns:mongo="http://springframework.org/schema/data/mongo"
xsi:schemaLocation="
http://springframework.org/schema/util http://springframework.org/schema/util/spring-util.xsd
http://springframework.org/schema/beans http://springframework.org/schema/beans/spring-beans.xsd
http://springframework.org/schema/context http://springframework.org/schema/context/spring-context.xsd
http://springframework.org/schema/data/mongo http://springframework.org/schema/data/mongo/sprihttp://ng-mongo.xsd">
ignore-unresolvable="true" location="classpath:/mongodb.properties"/> dbname="${mongo.database}" mongo-ref="mongoClient"/> type-mapper-ref="defaultMongoTypeMapper">
ignore-unresolvable="true" location="classpath:/mongodb.properties"/>
dbname="${mongo.database}" mongo-ref="mongoClient"/> type-mapper-ref="defaultMongoTypeMapper">
dbname="${mongo.database}"
mongo-ref="mongoClient"/>
type-mapper-ref="defaultMongoTypeMapper">
type-mapper-ref="defaultMongoTypeMapper">
mongo:mongo-client是定义MongoDB的客户端连接,需要host和port参数,如果需要账号密码的话,需要增加credentials配置
mongo:db-factory配置连接工厂,指定具体的连接数据库,本例默认为test
defaultMongoTypeMapper默认Mongodb类型映射
mongo:mapping-converterMongoDB的实体映射
mongoTemplate这是最主要的,定义模板类,依赖连接工厂和实体映射
这里举一个article的增删改查的例子。
相关实体Article.java
@Document(collection = "article_info")
public class Article {
@Id
private String id;//id
@Field("title")
private String title;//标题
@Field("url")
private String url;//链接
@Field("author")
@Field("tags")
private List
@Field("visit_count")
private Long visitCount;//访问次数
@Field("add_time")
private Date addTime;//添加时间
// get set方法省略
@Document(collection = "article_info")这个注解和Hibernate的注解Entiry非常相似,就是定义一个文档,对象MongoDB存储的Collection的名称是article_info
@Id指该字段是主键,不能缺少
@Field("add_time")指该字段映射MongoDB的实际字段,如果一致可以省略
ArticleRepository实际访问接口
@Repository("ArticleRepository")
public interface ArticleRepository extends PagingAndSortingRepository
//分页查询
public Page
//根据author查询
public List
public List
//忽略参数大小写
public List
//忽略所有参数大小写
public List
//排序
public List
public List
//自带排序条件
public List
}
Spring的data repository封装了一套增删改查的方法,就和JPA实现的一样,ArticleRepository继承PagingAndSortingRepository,就集成了常用的增删改查方法,比如save、findOne、exists、findAll、delete等等,可以采用默认实现方式来完成常用的增删改查操作。
测试上述各个方法ArticleRepositoryTest.java
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath*:applicationContext-mongo.xml"})
public class ArticleRepositoryTest {
@Autowired
private ArticleRepository articleRepository;
/**
* 新增记录
*/
@Test
public void add() {
//增加一条记录
Article article = new Article();
article.setId("1");
article.setTitle("MongoTemplate的基本使用");
article.setAuthor("kcy");
article.setUrl("http://jianshu.com/");
article.setTags(Arrays.asList("java", "mongodb", "spring"));
article.setVisitCount(0L);
article.setAddTime(new Date());
articleRepository.save(article);
//批量添加
List
for (int i = 0; i < 10; i++) {
Article article2 = new Article();
article2.setId(String.valueOf(i + 1));
article2.setTitle("MongoTemplate的基本使用");
article2.setAuthor("kcy");
article2.setUrl("http://jianshu.com" + i);
article2.setTags(Arrays.asList("java", "mongodb", "spring"));
article2.setVisitCount(0L);
article2.setAddTime(new Date());
articles.add(article2);
}
articleRepository.save(articles);
}
/**
* 修改记录,修改id为1的访问次数+1
*/
@Test
public void update() {
Article article = articleRepository.findOne("1");
article.setVisitCount(article.getVisitCount() + 1);
articleRepository.save(article);
}
/**
* 批量修改,查看author为kcy的统一修改为kcy2
*/
@Test
public void batchUpdate() {
List
articles.forEach(article -> {
article.setAuthor("kcy2");
});
articleRepository.save(articles);
}
/**
* 删除记录,删除id为10的
*/
@Test
public void delete() {
Article article = articleRepository.findOne("10");
articleRepository.delete(article);
}
@Test
public void batchDelete() {
List
articleRepository.delete(articles);
}
/**
* 查询所有
*
* @author 孔垂云
*/
@Test
public void findAll() {
Iterable
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
* 根据author查询
*
* @author 孔垂云
*/
@Test
public void findByAuthor() {
List
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
* 按照author和title查询
*
* @author 孔垂云
*/
@Test
public void findByAuthorAndTitle() {
List
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
*
* @author 孔垂云
*/
@Test
public void findByAuthorIgnoreCase() {
List
articles.forEach(article -> {
System.out.println(article.getId());
});
}
/**
* 忽略所有参数的大小写
*
* @author 孔垂云
*/
@Test
public void findByAuthorAndTitleAllIgnoreCase() {
List
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
* 根据author查询,并且以访问次数降序排序显示
*
* @author 孔垂云
*/
@Test
public void findByAuthorOrderByVisitCountDesc() {
List
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
*
* @author 孔垂云
*/
@Test
public void findByAuthorOrderByVisitCountAsc() {
List
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
* 自带排序条件
*
* @author 孔垂云
*/
@Test
public void findByAuthorBySort() {
List
articles.forEach(article -> {
System.out.println(article.toString());
});
}
/**
* 分页查询所有,并且排序
*/
@Test
public void findByPage() {
int page = 1;
int size = 2;
Pageable pageable = new PageRequest(page, size, new Sort(Direction.ASC, "VisitCount"));
Page
//总数量
System.out.println(pageInfo.getTotalElements());
//总页数
System.out.println(pageInfo.getTotalSFkzLEWqOPages());
for (Article article : pageInfo.getContent()) {
System.out.println(article.toString());
}
}
}
上面一段代码较长,基本上MongoDB常用的各种例子都讲清楚了,比如增加、批量增加、修改、删除、按id查找、按标题查询、分页等等。
源码下载
本工程详细源码
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~