Java Spring-data for mongodb

    spring项目提供了对大数据的支持,Spring-data 项目,其中有关于Spring Data ForMongodb的,研究了一下,弄了个小示例参考一下。

    application.xml

  

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
	xmlns:mongo="http://www.springframework.org/schema/data/mongo"
	xsi:schemaLocation="http://www.springframework.org/schema/context     
          http://www.springframework.org/schema/context/spring-context-3.0.xsd     
          http://www.springframework.org/schema/data/mongo     
          http://www.springframework.org/schema/data/mongo/spring-mongo-1.0.xsd     
          http://www.springframework.org/schema/beans     
          http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

	<mongo:mongo host="localhost" port="27017" />

	<bean id="mongoTemplate" class="org.springframework.data.document.mongodb.MongoTemplate">
		<constructor-arg ref="mongo" />
		<constructor-arg name="databaseName" value="his" />
		<constructor-arg name="defaultCollectionName" value="person" />
	</bean>

	<bean id="personRepository" class="com.mongo.dao.impl.PersonRepository">
		<property name="mongoTemplate" ref="mongoTemplate"></property>
	</bean>

	<context:annotation-config />

</beans> 

   Person.java

package com.nbey.data.forward.mongo.persistence;

import java.io.Serializable;

public class Person implements Serializable {
	 private static final long serialVersionUID = 3617931430808763429L;  
     
	    private String id;     
	    private String name;     
	    private int age;  
	    public Person() {  
	        super();  
	    }  
	    public Person(String id, String name, int age) {  
	        super();  
	        this.id = id;  
	        this.name = name;  
	        this.age = age;  
	    }  
	    /** 
	     * @return the id 
	     */  
	    public String getId() {  
	        return id;  
	    }  
	    /** 
	     * @param id the id to set 
	     */  
	    public void setId(String id) {  
	        this.id = id;  
	    }  
	    /** 
	     * @return the name 
	     */  
	    public String getName() {  
	        return name;  
	    }  
	    /** 
	     * @param name the name to set 
	     */  
	    public void setName(String name) {  
	        this.name = name;  
	    }  
	    /** 
	     * @return the age 
	     */  
	    public int getAge() {  
	        return age;  
	    }  
	    /** 
	     * @param age the age to set 
	     */  
	    public void setAge(int age) {  
	        this.age = age;  
	    }  
	    /** 
	     *  
	     * @param name 
	     * @param age 
	     */  
	    public Person(String name, int age) {  
	        super();  
	        this.name = name;  
	        this.age = age;  
	    }     
	  
	     public String toString() {     
	            return "Person[id="+id+",name="+name+",age="+age+"]";     
	        }    
}

   interface  AbstractRepository.java

package com.nbey.data.forward.mongo.manager;

import java.util.List;

import com.nbey.data.forward.mongo.persistence.Person;

public interface AbstractRepository {
	/** 
     *  
     *<b>function:</b>��Ӷ��� 
     * @author cuiran 
     * @createDate 2012-12-12 11:41:30 
     */  
    public void insert(Person person);   
      
    /** 
     *  
     *<b>function:</b>���ID���Ҷ��� 
     * @author cuiran 
     * @createDate 2012-12-12 11:41:41 
     */  
    public Person findOne(String id);     
    /** 
     *  
     *<b>function:</b>��ѯ���� 
     * @author cuiran 
     * @createDate 2012-12-12 16:26:06 
     */  
    public List<Person> findAll();     
      
    public List<Person> findByRegex(String regex);  
    /** 
     *  
     *<b>function:</b>ɾ��ָ����ID���� 
     * @author cuiran 
     * @createDate 2012-12-12 16:26:16 
     */  
    public void removeOne(String id);     
    /** 
     *  
     *<b>function:</b>ɾ������ 
     * @author cuiran 
     * @createDate 2012-12-12 16:25:40 
     */  
    public void removeAll();     
    /** 
     * ͨ��ID�ҵ����޸� 
     *<b>function:</b> 
     * @author cuiran 
     * @createDate 2012-12-12 16:25:51 
     */  
    public void findAndModify(String id);     
  
}

  PersonRepository.java

 

package com.nbey.data.forward.mongo.manager.impl;

import java.util.List;
import java.util.regex.Pattern;

import org.springframework.data.document.mongodb.MongoTemplate;
import org.springframework.data.document.mongodb.query.Criteria;
import org.springframework.data.document.mongodb.query.Query;
import org.springframework.data.document.mongodb.query.Update;
import org.springframework.transaction.annotation.Transactional;

import com.nbey.data.forward.mongo.manager.AbstractRepository;
import com.nbey.data.forward.mongo.persistence.Person;

@Transactional
public class PersonRepository implements AbstractRepository {
	private MongoTemplate mongoTemplate;

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#findAll()
	 */
	@Override
	public List<Person> findAll() {
		// TODO Auto-generated method stub
		return getMongoTemplate().find(new Query(), Person.class);

	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#findAndModify(java.lang.String)
	 */
	@Override
	public void findAndModify(String id) {
		// TODO Auto-generated method stub
		// new Query(Criteria.where("id").is(id)), new Update().inc("age", 3)

		getMongoTemplate().updateFirst(new Query(Criteria.where("id").is(id)),
				new Update().inc("age", 3));

	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#findByRegex(java.lang.String)
	 */
	@Override
	public List<Person> findByRegex(String regex) {
		// TODO Auto-generated method stub
		Pattern pattern = Pattern.compile(regex, Pattern.CASE_INSENSITIVE);
		Criteria criteria = new Criteria("name").regex(pattern.toString());
		return getMongoTemplate().find(new Query(criteria), Person.class);

	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#findOne(java.lang.String)
	 */
	@Override
	public Person findOne(String id) {
		// TODO Auto-generated method stub
		return getMongoTemplate().findOne(
				new Query(Criteria.where("id").is(id)), Person.class);

	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#insert(com.mongo.bean.Person)
	 */
	@Override
	public void insert(Person person) {
		// TODO Auto-generated method stub
		getMongoTemplate().insert(person);
	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#removeAll()
	 */
	@Override
	public void removeAll() {
		// TODO Auto-generated method stub
		List<Person> list = this.findAll();
		if (list != null) {
			for (Person person : list) {
				getMongoTemplate().remove(person);
			}
		}

	}

	/*
	 * (non-Javadoc)
	 * 
	 * @see com.mongo.dao.AbstractRepository#removeOne(java.lang.String)
	 */
	@Override
	public void removeOne(String id) {
		// TODO Auto-generated method stub
		Criteria criteria = Criteria.where("id").in(id);
		if (criteria == null) {
			Query query = new Query(criteria);
			if (query != null
					&& getMongoTemplate().findOne(query, Person.class) != null)
				getMongoTemplate().remove(
						getMongoTemplate().findOne(query, Person.class));
		}

	}

	/**
	 * @return the mongoTemplate
	 */
	public MongoTemplate getMongoTemplate() {
		return mongoTemplate;
	}

	/**
	 * @param mongoTemplate
	 *            the mongoTemplate to set
	 */
	public void setMongoTemplate(MongoTemplate mongoTemplate) {
		this.mongoTemplate = mongoTemplate;
	}

}

  Main.java

 

package com.nbey.data.forward.mongo.startup;

import java.util.List;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.nbey.data.forward.mongo.manager.AbstractRepository;
import com.nbey.data.forward.mongo.manager.impl.PersonRepository;
import com.nbey.data.forward.mongo.persistence.Person;

public class Main {
	private static Log log = LogFactory.getLog(Main.class.getName());

	private AbstractRepository pr = null;

	public void init() {
		
		ApplicationContext ctx = new ClassPathXmlApplicationContext(
				"application.xml");
		pr = (PersonRepository) ctx.getBean("personRepository");
	}

	public void insert() {

		Person p = new Person("cuiran", 27);
		pr.insert(p);
		
	}

	public void findOne() {
		String id = "50c83cb552c2ceb0463177d6";
		Person p = pr.findOne(id);
		log.debug(p);
	}

	public void listAll() {

		List<Person> list = pr.findAll();
		
		for (Person p : list) {
			log.debug(p.toString());
		}

	}

	public void start() {
		init();

		insert();
		listAll();

		findOne();
	}

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Main t = new Main();
		t.start();
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值