欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDB整合Spring實(shí)例詳細(xì)講解(含代碼)

 更新時(shí)間:2017年01月09日 14:34:24   作者:cuiran  
這篇文章主要介紹了MongoDB整合Spring實(shí)例詳細(xì)講解(含代碼),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

寫(xiě)這篇文章也做了下思考,首先是本人技術(shù)欠佳。但就是喜歡研究一些東西。因?yàn)樵诖酥坝泻芏嗟呐笥岩呀?jīng)寫(xiě)過(guò)類(lèi)似的,很多我也看過(guò),但是講解的不夠深入。對(duì)有些朋友提出的問(wèn)題不能給出答案。在這里,我根據(jù)我目前的能力對(duì)其進(jìn)行整理。并最終運(yùn)行成功。

在測(cè)試過(guò)程中出現(xiàn)過(guò)一下問(wèn)題:

1、org/springframework/data/mapping/context/MappingContextAware

2、src-resolve: Cannot resolve the name 'repository:repository' to a(n) 'type definition'

以上都是版本不匹配引起的。特別是第二個(gè)錯(cuò)誤我看有些解決時(shí)候提到了jpa,但是我這里沒(méi)有使用jpa后來(lái)我是把spring-data-commons的包替換了個(gè)版本就不出現(xiàn)了。

我先說(shuō)下我的開(kāi)發(fā)環(huán)境:

myeclipse 6.5

MongoDB 2.0.8

spring 3.0.4

最后就是下面2個(gè)(這兩個(gè)版本不對(duì)就容易出現(xiàn)各種各樣的,雜七雜八的問(wèn)題) 這里我就給出我所采用的版本

spring-data-document

spring-data-commons

有所改變所有版本必須要對(duì)應(yīng)好下面是jar下載地址

http://www.springsource.org/spring-data/mongodb

http://www.springsource.org/spring-data/commons

下載版本分別為:

spring-data-commons-dist-1.4.0.M1

spring-data-document-1.0.0.M2.zip

下面給出我工程的圖片

 

然后就開(kāi)始我們開(kāi)發(fā)之旅吧!

首先新建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="192.168.0.138" port="27017"/> 
     
     
   
    <bean id="mongoTemplate" class="org.springframework.data.document.mongodb.MongoTemplate">   
    <constructor-arg ref="mongo"/>   
    <constructor-arg name="databaseName" value="db"/>   
    <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>  

然后編寫(xiě)操作mongodb的接口

/** 
 * AbstractRepository.java 
 */ 
package com.mongo.dao; 
 
import java.util.List; 
 
import com.mongo.bean.Person; 
 
/** 
 * TODO 
 * @author cuiran 
 * @version TODO 
 */ 
public interface AbstractRepository { 
   
  /** 
   * 
   *<b>function:</b>添加對(duì)象 
   * @author cuiran 
   * @createDate 2012-12-12 11:41:30 
   */ 
  public void insert(Person person);  
   
  /** 
   * 
   *<b>function:</b>根據(jù)ID查找對(duì)象 
   * @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對(duì)象 
   * @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();   
  /** 
   * 通過(guò)ID找到并修改 
   *<b>function:</b> 
   * @author cuiran 
   * @createDate 2012-12-12 16:25:51 
   */ 
  public void findAndModify(String id);   
 
   
} 

再寫(xiě)對(duì)應(yīng)接口的實(shí)現(xiàn)類(lèi):

/** 
 * PersonRepository.java 
 */ 
package com.mongo.dao.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 com.mongo.bean.Person; 
import com.mongo.dao.AbstractRepository; 
 
/** 
 * TODO 
 * @author cuiran 
 * @version TODO 
 */ 
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; 
  } 
 
}  

這里也給出對(duì)應(yīng)Person對(duì)象代碼

/** 
 * Person.java 
 */ 
package com.mongo.bean; 
 
import java.io.Serializable; 
 
/** 
 * TODO 
 * @author cuiran 
 * @version TODO 
 */ 
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+"]";   
    }   
 
 
} 

最后寫(xiě)出我們的測(cè)試類(lèi)開(kāi)始進(jìn)行測(cè)試

/** 
 * MongoTest.java 
 */ 
package com.mongo.test; 
 
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.mongo.bean.Person; 
import com.mongo.dao.AbstractRepository; 
import com.mongo.dao.impl.PersonRepository; 
 
 
 
/** 
 * TODO 
 * @author cuiran 
 * @version TODO 
 */ 
public class MongoTest { 
 
  private static Log log = LogFactory.getLog(MongoTest.class.getName()); 
   
  private AbstractRepository pr=null; 
   
  /** 
   * 
   *<b>function:</b> 
   * @author cuiran 
   * @createDate 2012-12-12 16:08:02 
   */ 
  public void init(){ 
     log.debug("開(kāi)始啟動(dòng)"); 
     ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml"); 
     pr= (PersonRepository)ctx.getBean("personRepository"); 
      
     
     
  } 
  /** 
   * 
   *<b>function:</b>添加 
   * @author cuiran 
   * @createDate 2012-12-12 16:11:01 
   */ 
  public void insert(){ 
     
    Person p=new Person("cuiran",27); 
     pr.insert(p); 
     log.debug("添加成功"); 
  } 
  /** 
   * 
   *<b>function:</b>根據(jù)輸入的ID查找對(duì)象 
   * @author cuiran 
   * @createDate 2012-12-12 16:24:10 
   */ 
  public void findOne(){ 
    String id="50c83cb552c2ceb0463177d6"; 
    Person p= pr.findOne(id); 
    log.debug(p); 
  } 
   
   
  /** 
   * 
   *<b>function:</b>查詢所有 
   * @author cuiran 
   * @createDate 2012-12-12 16:08:54 
   */ 
  public void listAll(){ 
     
    List<Person> list=pr.findAll(); 
    log.debug("查詢結(jié)果如下:"); 
    for (Person p:list){ 
      log.debug(p.toString()); 
    } 
     
     
  } 
   
  /** 
   * 
   *<b>function:</b>測(cè)試方法 
   * @author cuiran 
   * @createDate 2012-12-12 16:11:37 
   */ 
  public void start(){ 
    init(); 
     
    //insert(); 
    //listAll(); 
     
    findOne(); 
  } 
   
  /** 
   *<b>function:</b>main函數(shù) 
   * @author cuiran 
   * @createDate 2012-12-12 11:54:30 
   */ 
  public static void main(String[] args) { 
    // TODO Auto-generated method stub 
    MongoTest t=new MongoTest(); 
    t.start(); 
  } 
 
} 

運(yùn)行出現(xiàn)一下日志,就沒(méi)什么問(wèn)題。

2012-12-12 16:23:59:DEBUG com.mongo.test.MongoTest - 開(kāi)始啟動(dòng) 
2012-12-12 16:23:59:INFO org.springframework.context.support.ClassPathXmlApplicationContext - Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@253498: startup date [Wed Dec 12 16:23:59 CST 2012]; root of context hierarchy 
2012-12-12 16:23:59:INFO org.springframework.beans.factory.xml.XmlBeanDefinitionReader - Loading XML bean definitions from class path resource [applicationContext.xml] 
2012-12-12 16:24:00:INFO org.springframework.beans.factory.support.DefaultListableBeanFactory - Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@12a0f6c: defining beans [mongo,mongoTemplate,personRepository,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor]; root of factory hierarchy 
2012-12-12 16:24:00:DEBUG com.mongo.test.MongoTest - Person[id=50c83cb552c2ceb0463177d6,name=cuiran,age=27] 

在此附上demo源碼:demo

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論