设为首页 收藏本站
查看: 944|回复: 0

[经验分享] Spring整合- mongodb

[复制链接]

尚未签到

发表于 2015-7-8 09:37:49 | 显示全部楼层 |阅读模式
  
1.环境
  
     Jdk:1.6.0_10-rc2
  
     Spring3.1.2  下载
  
     依赖jar文件:

  
   DSC0000.jpg

  
2.相关配置
  
①.Spring配置文件
  

















  ②.MongoTemplate  Api
  

package com.x.mongodb.dao.support;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.data.mongodb.core.MongoTemplate;
/**
* @author java2000_wl
* @version 1.0
*/
public abstract class AbstractBaseMongoTemplete implements ApplicationContextAware {
protected MongoTemplate mongoTemplate;
/**
* 设置mongoTemplate
* @param mongoTemplate the mongoTemplate to set
*/
public void setMongoTemplate(MongoTemplate mongoTemplate) {
this.mongoTemplate = mongoTemplate;
}
public void setApplicationContext(ApplicationContext applicationContext)
throws BeansException {
MongoTemplate mongoTemplate = applicationContext.getBean("mongoTemplate", MongoTemplate.class);
setMongoTemplate(mongoTemplate);
}
}


package com.x.mongodb.dao.impl;
import java.util.List;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import com.x.mongodb.dao.IUserDao;
import com.x.mongodb.dao.support.AbstractBaseMongoTemplete;
import com.x.mongodb.entity.User;
/**
* @author java2000_wl
* @version 1.0
*/
public class UserDao extends AbstractBaseMongoTemplete implements IUserDao {
/**
* 新增
* ------------------------------
* @param user
*/
public void insert(User user) {
mongoTemplate.insert(user);
}
/**
* 批量新增
* ------------------------------
* @param users
*/
public void insertAll(List users) {
mongoTemplate.insertAll(users);
}
/**
* 删除,按主键id, 如果主键的值为null,删除会失败
* ------------------------------
* @param id
*/
public void deleteById(String id) {
User user = new User(id, null, 0);
mongoTemplate.remove(user);
}
/**
* 按条件删除
* ------------------------------
* @param criteriaUser
*/
public void delete(User criteriaUser) {
Criteria criteria = Criteria.where("age").gt(criteriaUser.getAge());;
Query query = new Query(criteria);
mongoTemplate.remove(query, User.class);
}
/**
* 删除全部
* ------------------------------
*/
public void deleteAll() {
mongoTemplate.dropCollection(User.class);
}
/**
* 按主键修改,
* 如果文档中没有相关key 会新增 使用$set修改器
* ------------------------------
* @param user
*/
public void updateById(User user) {
Criteria criteria = Criteria.where("id").is(user.getId());
Query query = new Query(criteria);
Update update = Update.update("age", user.getAge()).set("name", user.getName());
mongoTemplate.updateFirst(query, update, User.class);
}
/**
* 修改多条
* ------------------------------
* @param criteriaUser
* @param user
*/
public void update(User criteriaUser, User user) {
Criteria criteria = Criteria.where("age").gt(criteriaUser.getAge());;
Query query = new Query(criteria);
Update update = Update.update("name", user.getName()).set("age", user.getAge());
mongoTemplate.updateMulti(query, update, User.class);
}
/**
* 根据主键查询
* ------------------------------
* @param id
* @return
*/
public User findById(String id) {
return mongoTemplate.findById(id, User.class);
}
/**
* 查询全部
* ------------------------------
* @return
*/
public List findAll() {
return mongoTemplate.findAll(User.class);
}
/**
* 按条件查询, 分页
* ------------------------------
* @param criteriaUser
* @param skip
* @param limit
* @return
*/
public List find(User criteriaUser, int skip, int limit) {
Query query = getQuery(criteriaUser);
query.skip(skip);
query.limit(limit);
return mongoTemplate.find(query, User.class);
}
/**
* 根据条件查询出来后 再去修改
* ------------------------------
* @param criteriaUser  查询条件
* @param updateUser    修改的值对象
* @return
*/
public User findAndModify(User criteriaUser, User updateUser) {
Query query = getQuery(criteriaUser);
Update update = Update.update("age", updateUser.getAge()).set("name", updateUser.getName());
return mongoTemplate.findAndModify(query, update, User.class);
}
/**
* 查询出来后 删除
* ------------------------------
* @param criteriaUser
* @return
*/
public User findAndRemove(User criteriaUser) {
Query query = getQuery(criteriaUser);
return mongoTemplate.findAndRemove(query, User.class);
}
/**
* count
* ------------------------------
* @param criteriaUser
* @return
*/
public long count(User criteriaUser) {
Query query = getQuery(criteriaUser);
return mongoTemplate.count(query, User.class);
}
/**
*
* ------------------------------
* @param criteriaUser
* @return
*/
private Query getQuery(User criteriaUser) {
if (criteriaUser == null) {
criteriaUser = new User();
}
Query query = new Query();
if (criteriaUser.getId() != null) {
Criteria criteria = Criteria.where("id").is(criteriaUser.getId());
query.addCriteria(criteria);
}
if (criteriaUser.getAge() > 0) {
Criteria criteria = Criteria.where("age").gt(criteriaUser.getAge());
query.addCriteria(criteria);
}
if (criteriaUser.getName() != null) {
Criteria criteria = Criteria.where("name").regex("^" + criteriaUser.getName());
query.addCriteria(criteria);
}
return query;
}
}

package com.x.mongodb.dao;
import java.util.List;
import com.x.mongodb.entity.User;
/**
* @author java2000_wl
* @version 1.0
*/
public interface IUserDao {
/**
* 新增
* ------------------------------
* @param user
*/
void insert(User user);
/**
* 新增
* ------------------------------
* @param users
*/
void insertAll(List users);
/**
* 删除,主键id, 如果主键的值为null,删除会失败
* ------------------------------
* @param id
*/
void deleteById(String id);
/**
* 按条件删除
* ------------------------------
* @param criteriaUser
*/
void delete(User criteriaUser);
/**
* 删除全部
* ------------------------------
*/
void deleteAll();
/**
* 修改
* ------------------------------
* @param user
*/
void updateById(User user);
/**
* 更新多条
* ------------------------------
* @param criteriaUser
* @param user
*/
void update(User criteriaUser, User user);
/**
* 根据主键查询
* ------------------------------
* @param id
* @return
*/
User findById(String id);
/**
* 查询全部
* ------------------------------
* @return
*/
List findAll();
/**
* 按条件查询
* ------------------------------
* @param criteriaUser
* @param skip
* @param limit
* @return
*/
List find(User criteriaUser, int skip, int limit);
/**
* 根据条件查询出来后 在去修改
* ------------------------------
* @param criteriaUser  查询条件
* @param updateUser    修改的值对象
* @return
*/
User findAndModify(User criteriaUser, User updateUser);
/**
* 查询出来后 删除
* ------------------------------
* @param criteriaUser
* @return
*/
User findAndRemove(User criteriaUser);
/**
* count
* ------------------------------
* @param criteriaUser
* @return
*/
long count(User criteriaUser);
}


package com.x.mongodb.entity;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
/**
* @author java2000_wl
* @version 1.0
*/
public class User implements Serializable {
private static final long serialVersionUID = -5785857960597910259L;
private String id;
private String name;
private int age;
/**
* ------------------------------
*/
public User() {
}
/**
*
* ------------------------------
* @param id
* @param name
* @param age
*/
public User(String id, String name, int age) {
super();
this.id = id;
this.name = name;
this.age = age;
}
/**
* 获得id
* @return the id
*/
public String getId() {
return id;
}
/**
* 设置id
* @param id the id to set
*/
public void setId(String id) {
this.id = id;
}
/**
* 获得name
* @return the name
*/
public String getName() {
return name;
}
/**
* 设置name
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}
/**
* 获得age
* @return the age
*/
public int getAge() {
return age;
}
/**
* 设置age
* @param age the age to set
*/
public void setAge(int age) {
this.age = age;
}
/**
* toString
*/
public String toString() {
Map map = new HashMap();
map.put("id", id);
map.put("name", name);
map.put("age", String.valueOf(age));
return map.toString();
}
}

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.x.mongodb.dao.IUserDao;
import com.x.mongodb.entity.User;
/**
* @author java2000_wl
* @version 1.0
*/
public class UserDaoTest {
/**
* 新增
* ------------------------------
*/
@Test
public void testInsert() {
getUserDao().insert(new User(null, "testUser", 21));
}
/**
* 批量新增
* ------------------------------
*/
@Test
public void testInsertAll() {
List list = new ArrayList();
for (int i = 0; i < 10; i++) {
list.add(new User(null, &quot;testUser&quot; + i, 21 + i));
}
getUserDao().insertAll(list);
}
/**
* 根据主键删除
* ------------------------------
*/
@Test
public void testDeleteById() {
String id = &quot;5058184ec85607e42c4bfad8&quot;;
getUserDao().deleteById(id);
}
/**
* 条件删除
* ------------------------------
*/
@Test
public void testDelete() {
//删除年龄大于25的
getUserDao().delete(new User(null, null, 25));
}
/**
* 删除全部
* ------------------------------
*/
@Test
public void testDeleteAll() {
getUserDao().deleteAll();
}
/**
* 修改  根据id修改
* ------------------------------
*/
@Test
public void testUpdateById() {
getUserDao().updateById(new User(&quot;50581c08c856346f02e9842c&quot;, &quot;张三&quot;, 100));
}
/**
* 修改多个
* ------------------------------
*/
@Test
public void update() {
//修改年龄大于29岁的 姓名为“王五“
User criteriaUser = new User(null, null, 29);
User user = new User(null, &quot;王五&quot;, 39);
getUserDao().update(criteriaUser, user);
}
/**
* 按主键查询, 如果不存在 返回null
* ------------------------------
*/
@Test
public void testFindById() {
User user = getUserDao().findById(&quot;50581c08c856346f02e98425&quot;);
print(user);
}
/**
* 查询全部
* ------------------------------
*/
@Test
public void testFindAll() {
List list = getUserDao().findAll();
print(list);
}
/**
* 按条件查询
* ------------------------------
*/
@Test
public void testFind() {
//查询25岁以上的, 分页
User criteriaUser = new User(null, null, 20);
List list = getUserDao().find(criteriaUser, 1, 10);
print(list);
}
/**
* 查询出来后  修改
* ------------------------------
*/
@Test
public void testFindAndModify() {
User criteriaUser = new User(&quot;50581c08c856346f02e9842d&quot;, null, 0);
User updateUser = new User(null, &quot;张三&quot;, 100);
updateUser = getUserDao().findAndModify(criteriaUser, updateUser);
print(updateUser);
}
/**
* 查询出来后 删除
* ------------------------------
*/
@Test
public void testFindAndRemove() {
User criteriaUser = new User(&quot;50581c08c856346f02e9842d&quot;, null, 0);
criteriaUser = getUserDao().findAndRemove(criteriaUser);
print(criteriaUser);
}
/**
* count
* ------------------------------
*/
@Test
public void testCount() {
User criteriaUser = new User(null, &quot;test&quot;, 0);
long count = getUserDao().count(criteriaUser);
print(count);
}
public void print(Object object) {
if (object == null || !(object instanceof Collection)) {
System.out.println(object);
return;
}
List list = (List) object;
for (Object obj : list) {
System.out.println(obj);
}
}
public IUserDao getUserDao() {
String configLocations = &quot;applicationContext.xml&quot;;
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(configLocations);
IUserDao userDao = applicationContext.getBean(&quot;userDao&quot;, IUserDao.class);
return userDao;
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-84386-1-1.html 上篇帖子: mongodb指南(翻译)(七) 下篇帖子: MongoDB线程安全批量处理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表