MongoDB是一个基于分布式文件存储的数据库。由
C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 是一个介于
关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似
json的
bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立
索引。
安装: 直接下载mongdb偶数版本,解压。然后配置环境变量(到bin目录),进入cmd, 输入mongdb --version查看是否安装完成。
具体命令可参考:http://www.runoob.com/mongodb/mongodb-dropdatabase.html
mongdb的spring配置文件:
<?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/beans
http://www.springframework.org/schema/beans/spring-beans-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/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<!-- 加载mongodb的属性配置文件 -->
<!-- <context:property-placeholder location="classpath:mongo.properties" /> -->
<!-- 定义mongo对象,对应的是mongodb官方jar包中的Mongo,replica-set设置集群副本的ip地址和端口 -->
<mongo:mongo id="mongo" replica-set="${mongo.hostport}">
<!-- 一些连接属性的设置 -->
<mongo:options connections-per-host="${mongo.connectionsPerHost}"
threads-allowed-to-block-for-connection-multiplier="${mongo.threadsAllowedToBlockForConnectionMultiplier}"
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的工厂,通过它来取得mongo实例,dbname为mongodb的数据库名,没有的话会自动创建 -->
<mongo:db-factory dbname="test" mongo-ref="mongo"
username="${mongo.username}" password="${mongo.password}"/>
<!-- mongodb的主要操作对象,所有对mongodb的增删改查的操作都是通过它完成 -->
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
</bean>
<!-- 映射转换器,扫描back-package目录下的文件,根据注释,把它们作为mongodb的一个collection的映射 -->
<mongo:mapping-converter base-package="com.mongo.bean" />
<!-- mongodb bean的仓库目录,会自动扫描扩展了MongoRepository接口的接口进行注入 -->
<!-- <mongo:repositories base-package="com.mongo.dao.impl" /> -->
<!-- 注解扫描dao.impl,这里只使用了dao层,没有service层-->
<context:component-scan base-package="com.mongo.dao.impl" />
<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/beans
http://www.springframework.org/schema/beans/spring-beans-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/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<!-- 加载mongodb的属性配置文件 -->
<!-- <context:property-placeholder location="classpath:mongo.properties" /> -->
<!-- 定义mongo对象,对应的是mongodb官方jar包中的Mongo,replica-set设置集群副本的ip地址和端口 -->
<mongo:mongo id="mongo" replica-set="${mongo.hostport}">
<!-- 一些连接属性的设置 -->
<mongo:options connections-per-host="${mongo.connectionsPerHost}"
threads-allowed-to-block-for-connection-multiplier="${mongo.threadsAllowedToBlockForConnectionMultiplier}"
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的工厂,通过它来取得mongo实例,dbname为mongodb的数据库名,没有的话会自动创建 -->
<mongo:db-factory dbname="test" mongo-ref="mongo"
username="${mongo.username}" password="${mongo.password}"/>
<!-- mongodb的主要操作对象,所有对mongodb的增删改查的操作都是通过它完成 -->
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
</bean>
<!-- 映射转换器,扫描back-package目录下的文件,根据注释,把它们作为mongodb的一个collection的映射 -->
<mongo:mapping-converter base-package="com.mongo.bean" />
<!-- mongodb bean的仓库目录,会自动扫描扩展了MongoRepository接口的接口进行注入 -->
<!-- <mongo:repositories base-package="com.mongo.dao.impl" /> -->
<!-- 注解扫描dao.impl,这里只使用了dao层,没有service层-->
<context:component-scan base-package="com.mongo.dao.impl" />
<!-- 使用注解-->
<context:annotation-config />
</beans>
DaoImpl层中需要注入:
@Autowired
private MongoTemplate mongoTemplate;
private MongoTemplate mongoTemplate;
创建集合:
public void createCollection(T object) {
if (!this.mongoTemplate.collectionExists(clazz)) {
this.mongoTemplate.createCollection(clazz);
}
}
if (!this.mongoTemplate.collectionExists(clazz)) {
this.mongoTemplate.createCollection(clazz);
}
}
FindObejct:
public T findOneByItems(Map<String, Object> params) {
Query query = new Query();
if ((params != null) && (!(params.isEmpty()))) {
for (String key : params.keySet()) {
query.addCriteria(new Criteria(key).is(params.get(key)));
}
}
return (T)mongoTemplate.findOne(query, clazz);
}
Query query = new Query();
if ((params != null) && (!(params.isEmpty()))) {
for (String key : params.keySet()) {
query.addCriteria(new Criteria(key).is(params.get(key)));
}
}
return (T)mongoTemplate.findOne(query, clazz);
}
插入:
public void insert(T t) {
this.mongoTemplate.insert(t);
}
this.mongoTemplate.insert(t);
}
批量插入:
public void insertAll(List<T> all) {
mongoTemplate.insertAll(all);
}
mongoTemplate.insertAll(all);
}
更新:
public void update(Map<String, Object> whereParams,Map<String, Object> updateParams){
Query query = new Query();
//更新条件
if ((whereParams != null) && (!(whereParams.isEmpty()))) {
for (String key : whereParams.keySet()) {
query.addCriteria(new Criteria(key).is(whereParams.get(key))); // 传入的条件
}
}
//更新的字段
Update update = new Update();
if ((updateParams != null) && (!(updateParams.isEmpty()))) {
for (String key : updateParams.keySet()) {
update.set(key, updateParams.get(key)); // 更新的内容
}
}
this.mongoTemplate.updateMulti(query,update,clazz);
}
Query query = new Query();
//更新条件
if ((whereParams != null) && (!(whereParams.isEmpty()))) {
for (String key : whereParams.keySet()) {
query.addCriteria(new Criteria(key).is(whereParams.get(key))); // 传入的条件
}
}
//更新的字段
Update update = new Update();
if ((updateParams != null) && (!(updateParams.isEmpty()))) {
for (String key : updateParams.keySet()) {
update.set(key, updateParams.get(key)); // 更新的内容
}
}
this.mongoTemplate.updateMulti(query,update,clazz);
}
删除:
public void deleteById(String id) {
mongoTemplate.remove(new Query(Criteria.where("_id").is(id)), clazz);
}
mongoTemplate.remove(new Query(Criteria.where("_id").is(id)), clazz);
}
分页:
public List<T> findListByPageAndItems(int skip, int rows, Map<String, Object> params) {
Query query = new Query();
if ((params != null) && (!(params.isEmpty()))) {
for (String key : params.keySet()) {
query.addCriteria(new Criteria(key).is(params.get(key)));
}
}
query.skip(skip).limit(rows);
return (List<T>)this.mongoTemplate.find(query, clazz);
}
Query query = new Query();
if ((params != null) && (!(params.isEmpty()))) {
for (String key : params.keySet()) {
query.addCriteria(new Criteria(key).is(params.get(key)));
}
}
query.skip(skip).limit(rows);
return (List<T>)this.mongoTemplate.find(query, clazz);
}
保存文件:
public void saveFile(File file, String fileUrl) {
try {
DB db = mongoTemplate.getDb();
GridFS fs = new GridFS(db, FILEURL); // 存 放大量小文件
GridFSInputFile inputFile = fs.createFile(file);
inputFile.setFilename(fileUrl);
inputFile.setContentType(fileUrl.substring(fileUrl.lastIndexOf(".")));
inputFile.save();
} catch (IOException e) {
e.printStackTrace();
}
}
try {
DB db = mongoTemplate.getDb();
GridFS fs = new GridFS(db, FILEURL); // 存 放大量小文件
GridFSInputFile inputFile = fs.createFile(file);
inputFile.setFilename(fileUrl);
inputFile.setContentType(fileUrl.substring(fileUrl.lastIndexOf(".")));
inputFile.save();
} catch (IOException e) {
e.printStackTrace();
}
}
检索文件是否存在:
public GridFSDBFile retrieveFileOne(String filename) {
try {
DB db = mongoTemplate.getDb();
// 获取fs的根节点
GridFS gridFS = new GridFS(db, FILEURL);
GridFSDBFile dbfile = gridFS.findOne(filename);
if (dbfile != null) {
return dbfile;
}
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
try {
DB db = mongoTemplate.getDb();
// 获取fs的根节点
GridFS gridFS = new GridFS(db, FILEURL);
GridFSDBFile dbfile = gridFS.findOne(filename);
if (dbfile != null) {
return dbfile;
}
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
public BaseDaoImpl() {
//得到泛型类超类
ParameterizedType type=(ParameterizedType) this.getClass().getGenericSuperclass();
clazz =(Class<T>) type.getActualTypeArguments()[0];
}
//得到泛型类超类
ParameterizedType type=(ParameterizedType) this.getClass().getGenericSuperclass();
clazz =(Class<T>) type.getActualTypeArguments()[0];
}