Spring-data-mongo配置示例

參考:http://docs.spring.io/spring-data/data-mongo/docs/1.8.0.M1/reference/html/#mongo.mongo-xml-config html

1、applicationContext-mongodb.propertiesjava

#若是,mongodb有配置集羣url間能夠使用 ","隔開spring

mongo.url=192.168.1.156:27017mongodb

mongo.dbname=autocompleteapp

mongo.username=easysocket

mongo.password=easy測試

mongo.connectTimeout=3000this

mongo.maxWaitTime=60000url

mongo.autoConnectRetry=truespa

mongo.socketKeepAlive=true

mongo.socketTimeout=0

mongo.slaveOk=true

#鏈接池鏈接數

mongo.connectionsPerHost=20

2、applicationContext-mongodb.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:jee="http://www.springframework.org/schema/jee"

xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"

xmlns:aop="http://www.springframework.org/schema/aop" xmlns:mongo="http://www.springframework.org/schema/data/mongo"

xsi:schemaLocation="http://www.springframework.org/schema/beans 

http://www.springframework.org/schema/beans/spring-beans-4.0.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-4.0.xsd

http://www.springframework.org/schema/jee

http://www.springframework.org/schema/jee/spring-jee-4.0.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop-4.0.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-4.0.xsd

http://www.springframework.org/schema/data/mongo

http://www.springframework.org/schema/data/mongo/spring-mongo-1.7.xsd"

default-lazy-init="true">


<mongo:mongo id="mongo" replica-set="${mongo.url}">

<mongo:options connections-per-host="${mongo.connectionsPerHost}"

threads-allowed-to-block-for-connection-multiplier="15"

connect-timeout="${mongo.connectTimeout}" max-wait-time="${mongo.maxWaitTime}"

auto-connect-retry="${mongo.autoConnectRetry}" socket-keep-alive="${mongo.socketKeepAlive}"

socket-timeout="${mongo.socketTimeout}" slave-ok="${mongo.slaveOk}"

write-number="1" write-timeout="0" write-fsync="true" />

</mongo:mongo>


<mongo:db-factory id="mongoDbFactory" dbname="${mongo.dbname}"

mongo-ref="mongo" username="${mongo.username}" password="${mongo.password}" />


<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">

<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />

</bean>

<!-- spring data,repositories 配置 -->

<mongo:repositories base-package="cn.com.easy.mongodb.dao" />

</beans>

3、測試用例


package cn.com.easy.mongodb.entry;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;
/**
 * 搜索建議詞條
 * 
 * @author nibili 2015年6月19日
 * 
 */
@Document
public class Word {
public static final String ID_FIELD = "id";
public static final String TEXT_FIELD = "text";
public static final String USECOUNT_FIELD = "useCount";
public static final String RESULTCOUNT_FIELD = "resultCount";
@Id
private String id;
/** 文本 */
private String text;
/** 拼音 */
private String pinyin;
/** 拼音首字母縮寫 */
private String initials;
/** 使用次數 */
private Integer useCount;
/** 結果集大小 */
private Integer resultCount;
/**
 * get id
 * 
 * @return
 * @auth nibili 2015年6月19日
 */
public String getId() {
return id;
}
/**
 * set id
 * 
 * @param id
 * @auth nibili 2015年6月19日
 */
public void setId(String id) {
this.id = id;
}
/**
 * get 文本
 * 
 * @return
 * @auth nibili 2015年6月19日
 */
public String getText() {
return text;
}
/**
 * set 文本
 * 
 * @param text
 * @auth nibili 2015年6月19日
 */
public void setText(String text) {
this.text = text;
}
/**
 * get 拼音
 * 
 * @return
 * @auth nibili 2015年6月19日
 */
public String getPinyin() {
return pinyin;
}
/**
 * set 拼音
 * 
 * @param pinyin
 * @auth nibili 2015年6月19日
 */
public void setPinyin(String pinyin) {
this.pinyin = pinyin;
}
/**
 * get 拼音首字母縮寫
 * 
 * @return
 * @auth nibili 2015年6月19日
 */
public String getInitials() {
return initials;
}
/**
 * set 拼音首字母縮寫
 * 
 * @param initials
 * @auth nibili 2015年6月19日
 */
public void setInitials(String initials) {
this.initials = initials;
}
/**
 * get 使用次數
 * 
 * @return
 * @auth nibili 2015年6月19日
 */
public Integer getUseCount() {
return useCount;
}
/**
 * set 使用次數
 * 
 * @param useCount
 * @auth nibili 2015年6月19日
 */
public void setUseCount(Integer useCount) {
this.useCount = useCount;
}
/**
 * get 結果集大小
 * 
 * @return
 * @auth nibili 2015年6月19日
 */
public Integer getResultCount() {
return resultCount;
}
/**
 * set 結果集大小
 * 
 * @param resultCount
 * @auth nibili 2015年6月19日
 */
public void setResultCount(Integer resultCount) {
this.resultCount = resultCount;
}
}



import static org.springframework.data.mongodb.core.query.Criteria.where;
import java.util.List;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import cn.com.easy.mongodb.entry.Word;
import cn.com.easy.utils.FastJSONUtils;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("/applicationContext-mongodb-demo.xml")
public class MongoTest {
private static final Logger log = LoggerFactory.getLogger(MongoTest.class);
@Autowired
private MongoTemplate mongoTemplate;
/**
 * mongo插入
 * 
 * @auth nibili 2015年6月19日
 */
@Test
public void insert() {
try {
Word word = new Word();
word.setInitials("sj");
word.setPinyin("shouji");
word.setResultCount(10);
word.setText("手機");
word.setUseCount(100);
//
mongoTemplate.insert(word);
//
word = mongoTemplate.findOne(new Query(where(Word.TEXT_FIELD).is("手機")), Word.class);
log.info("結果:" + FastJSONUtils.toJsonString(word));
List<Word> list = mongoTemplate.findAll(Word.class);
log.info("結果List:" + FastJSONUtils.toJsonString(list));
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
相關文章
相關標籤/搜索