MongoDB应用例子

[b]MongoDB应用例子[/b]


[b]JDBC应用例子:[/b]
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongodb-driver</artifactId>
<version>3.2.2</version>
</dependency>


import java.util.ArrayList;
import java.util.List;

import org.bson.Document;

import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;

public class MongoDBJDBC {
public static void main(String args[]) {
try {
// 连接到MongoDB服务 如果是远程连接可以替换“localhost”为服务器所在IP地址
// ServerAddress()两个参数分别为 服务器地址 和 端口
ServerAddress serverAddress = new ServerAddress("localhost", 27017);
List<ServerAddress> addrs = new ArrayList<ServerAddress>();
addrs.add(serverAddress);

// MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码
MongoCredential credential = MongoCredential.createScramSha1Credential("admin", "admin",
"admin".toCharArray());
List<MongoCredential> credentials = new ArrayList<MongoCredential>();
credentials.add(credential);

// 通过连接认证获取MongoDB连接
MongoClient mongoClient = new MongoClient(addrs, credentials);

// 连接到数据库
MongoDatabase mongoDatabase = mongoClient.getDatabase("testDB"); // 得到要操作的数据库

MongoCollection<Document> collection = mongoDatabase.getCollection("test");// 得到要操作的集合
if (collection == null) {
mongoDatabase.createCollection("test");// 集合创建
System.out.println("集合创建成功");
System.out.println("Connect to database successfully");
}

collection = mongoDatabase.getCollection("test");// 得到要操作的集合
System.out.println("集合 test 选择成功");
// 插入文档
/**
* 1. 创建文档 org.bson.Document 参数为key-value的格式 2. 创建文档集合List
* <Document> 3. 将文档集合插入数据库集合中 mongoCollection.insertMany(List
* <Document>) 插入单个文档可以用 mongoCollection.insertOne(Document)
*/
Document document = new Document("title", "MongoDB").append("description", "database").append("likes", 100)
.append("by", "Fly"); // 新建文档集
List<Document> documents = new ArrayList<Document>();
documents.add(document);
collection.insertMany(documents);// 向集合插入文档集

System.out.println("文档插入成功");

// 检索所有文档
/**
* 1. 获取迭代器FindIterable<Document> 2. 获取游标MongoCursor<Document> 3.
* 通过游标遍历检索出的文档集合
*/
FindIterable<Document> findIterable = collection.find(); // 查找所有文档集合
MongoCursor<Document> mongoCursor = findIterable.iterator();
while (mongoCursor.hasNext()) {
System.out.println(mongoCursor.next());
}

mongoClient.close(); // 关闭连接
} catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage());
}
}
}


参考原文(JDBC应用):[url]http://www.runoob.com/mongodb/mongodb-java.html[/url]


[b]spring data mongodb(MongoTemplate)[/b]

<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-mongodb</artifactId>
<version>1.9.3.RELEASE</version>
</dependency>


applicationContext.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"
xmlns:dwr="http://www.directwebremoting.org/schema/spring-dwr"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
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.directwebremoting.org/schema/spring-dwr http://www.directwebremoting.org/schema/spring-dwr-3.0.xsd">

<context:annotation-config />
<!-- <task:annotation-driven /> -->
<context:component-scan base-package="com" />

<mongo:mongo host="localhost" port="27017" >
<!-- 可选项如果不配置则为值为默认 -->
<mongo:options
connections-per-host="8"
threads-allowed-to-block-for-connection-multiplier="4"
connect-timeout="1000"
max-wait-time="1500"
auto-connect-retry="true"
socket-keep-alive="true"
socket-timeout="1500"
slave-ok="true"
write-number="1"
write-timeout="0"
write-fsync="true"
/>
</mongo:mongo>

<mongo:db-factory id="anotherMongoDbFactory"
host="localhost"
port="27017"
dbname="admin"
username="admin"
password="admin" mongo-ref="mongo"/>

<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongoDbFactory" ref="anotherMongoDbFactory" />
<!-- <constructor-arg ref="mongo" />
<constructor-arg name="databaseName" value="test" />链接数据库的名字 -->
</bean>
<bean id="natureRepository"
class="com.NatureRepositoryImpl">
</bean>
</beans>



package com;

public class Address {
private String addr;
private String pro;

public String getAddr() {
return addr;
}

public void setAddr(String addr) {
this.addr = addr;
}

public String getPro() {
return pro;
}

public void setPro(String pro) {
this.pro = pro;
}
}



package com;

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document
public class Person {
@Id
private String id;
private String name;
private int age;

private Address address;

public String getId() {
return id;
}

public void setId(String id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public int getAge() {
return age;
}

public void setAge(int age) {
this.age = age;
}

public Address getAddress() {
return address;
}

public void setAddress(Address address) {
this.address = address;
}

@Override
public String toString() {
return "Person [id=" + id + ", name=" + name + ", age=" + age + ", address=" + address + "]";
}

}



package com;

import java.util.List;

import com.mongodb.WriteResult;

public interface Repository<T> {

public List<T> getAllObjects();

public void saveObject(T object);

public T getObject(String id);

public WriteResult updateObject(String id, String name);

public void deleteObject(String id);

public void createCollection();

public void dropCollection();
}


package com;

import java.util.List;

import javax.annotation.Resource;

import org.springframework.data.mongodb.core.MongoTemplate;
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.mongodb.WriteResult;

public class NatureRepositoryImpl implements Repository<Person> {
@Resource
MongoTemplate mongoTemplate;

public List<Person> getAllObjects() {
return mongoTemplate.findAll(Person.class);
}

public void saveObject(Person tree) {
mongoTemplate.insert(tree);
}

public Person getObject(String id) {
// return mongoTemplate.find(new Query(Criteria.where("id").is(id)),
// Person.class).get(0);
return mongoTemplate.findById(id, Person.class);
}

public WriteResult updateObject(String id, String name) {
return mongoTemplate.updateFirst(new Query(Criteria.where("id").is(id)), Update.update("name", name),
Person.class);
}

public void deleteObject(String id) {
mongoTemplate.remove(new Query(Criteria.where("id").is(id)), Person.class);
}

public void createCollection() {
if (!mongoTemplate.collectionExists(Person.class)) {
mongoTemplate.createCollection(Person.class);
}
}

public void dropCollection() {
if (mongoTemplate.collectionExists(Person.class)) {
mongoTemplate.dropCollection(Person.class);
}
}
}



package com;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MongoTest {
public static void main(String[] args) throws InterruptedException {
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:/applicationContext.xml");

Repository<Person> repository = applicationContext.getBean(NatureRepositoryImpl.class);
System.out.println(repository);

repository.dropCollection();
repository.createCollection();
Person person = new Person();
Address address = new Address();

address.setAddr("合肥");
address.setPro("安徽");
person.setAddress(address);
person.setAge(20);
person.setName("senssic");
person.setId("1");
repository.saveObject(person);

System.out.println("1. " + repository.getAllObjects().toString());
person.setId("101");
repository.saveObject(person);
System.out.println("2. " + repository.getAllObjects().toString());

person = repository.getObject("1");
System.out.println(person.toString());

System.out.println("合肥");
repository.updateObject("1", "sen");
System.out.println("3. " + repository.getAllObjects().toString());
repository.deleteObject("1");
System.out.println("4. " + repository.getAllObjects().toString());
}
}


参考原文(配置参数):[url]http://blog.csdn.net/freebird_lb/article/details/8229567[/url]
参考原文(配置参数):[url]http://www.cnblogs.com/basecn/p/springmongo_intergration_cfg.html[/url]
参考原文:[url]http://www.xuebuyuan.com/2207064.html[/url]
参考原文(Query(查询语句)):[url]http://www.07net01.com/2015/08/889188.html[/url]
参考原文:[url]http://docs.spring.io/spring-data/mongodb/docs/current/reference/html/[/url]
参考原文:[url]http://blog.csdn.net/zhongweijian/article/details/7625286[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值