MongoDB集成及其基本使用

一、MongoDB概述

简介

MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

基础概念

在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。

下表将帮助您更容易理解Mongo中的一些概念:

SQL术语/概念

MongoDB术语/概念

解释/说明

database

database

数据库

table

collection

数据库表/集合

row

document

数据记录行/文档

column

field

数据字段/

index

index

索引

table joins

 

表连接,MongoDB不支持

primary key

primary key

主键,MongoDB自动将_id字段设置为主键


主要特性

MongoDB 包含以下特点:

a  面向集合的存储:适合存储对象及JSON形式的数据。

b  动态查询:Mongo 支持丰富的查询方式,查询指令使用 JSON 形式的标记,可轻易查询文档中内嵌的对象及数组。

c  完整的索引支持:包括文档内嵌对象及数组。Mongo 的查询优化器会分析查询表达式,并生成一个高效的查询计划。

d  查询监视:Mongo包含一个监控工具用于分析数据库操作性能。

e  复制及自动故障转移:Mongo 数据库支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目的是提供冗余及自动故障转移。

f  高效的传统存储方式:支持二进制数据及大型对象(如:照片或图片)。

g 自动分片以支持云级别的伸缩性:自动分片功能支持水平的数据库集群,可动态添加额外的机器。

二、MongoDB与 springMVC整合

环境

jdk1.8,spring-4.3.12.RELEASE

Maven依赖

         <dependency>
		    <groupId>org.springframework.data</groupId>
		    <artifactId>spring-data-mongodb</artifactId>
		    <version>1.9.6.RELEASE</version>
		</dependency>
        <dependency>
        	<groupId>org.mongodb</groupId>
        	<artifactId>mongo-java-driver</artifactId>
        	<version>2.14.3</version>
        </dependency>

配置

1,mongodb.propertise的配置(示例供参考)

mongo.hostport=127.0.0.1:27017
mongo.connectionsPerHost=8
mongo.threadsAllowedToBlockForConnectionMultiplier=4
#\u8FDE\u63A5\u8D85\u65F6\u65F6\u95F4
mongo.connectTimeout=1000
#\u7B49\u5F85\u65F6\u95F4
mongo.maxWaitTime=1500
mongo.autoConnectRetry=true
mongo.socketKeepAlive=true
#Socket\u8D85\u65F6\u65F6\u95F4
mongo.socketTimeout=1500
mongo.slaveOk=true

2,web.xml配置

3,Spring公共配置applicationContext-main.xml加载mongodb.properties

4,配置applicationContext-mongo.xml

三、基本操作

//新增

public void save(Object objectToSave)

//删除

public WriteResult remove(Object object)

//修改一个

public WriteResult updateFirst(Query query, Update update, Class<?> entityClass)

//修改多条记录

public WriteResult updateMulti(Query query, Update update, Class<?> entityClass)

//查第一个对象

public <T> T findOne(Query query, Class<T> entityClass)

//查对象列表

public <T> List<T> find(Query query, Class<T> entityClass)

等等

四、相关注解

@Document - 用于类,以表示这个类需要映射到数据库,您也可以指定映射到数据库的集合名称

@Id - 用于字段级别,标记这个字段是一个主键,默认生成的名称是“_id”

@DBRef - 用于字段,以表示它将使用com.mongodb.DBRef进行存储。

@Indexed - 用于字段,表示该字段需要如何创建索引

@CompoundIndex - 用于类,以声明复合索引

@GeoSpatialIndexed - 用于字段,进行地理位置索引

@TextIndexed - 用于字段,标记该字段要包含在文本索引中

@Field - 用于字段,并描述字段的名称,因为它将在MongoDB BSON文档中表示,允许名称与该类的字段名不同。
@Version - 用于字段锁定,保存操作时检查修改。初始值是0,每次更新时自动触发。

@Language - 用于字段,以设置文本索引的语言覆盖属性。

@Transient - 默认情况下,所有私有字段都映射到文档,此注解将会去除此字段的映射

@PersistenceConstructor - 标记一个给定的构造函数,即使是一个protected修饰的,在从数据库实例化对象时使用。构造函数参数通过名称映射到检索的DBObject中的键值。

五、实例代码示范

	@Autowired
	MongoTemplate mongoTemplate;
	
    
    //增
    @Test
	public void saveObj(){
    	KeyValue t = new KeyValue();
    	t.setKey("book");
    	t.setValue("javaScript");
    	mongoTemplate.save(t);
    	System.out.println("新增成功");
    	
    }
    //删
    @Test
    public void removeObj(){
    	//查询第一条数据并删除
    	KeyValue t = mongoTemplate.findOne(Query.query(Criteria.where("")),KeyValue.class);
    	
    	mongoTemplate.remove(t);
    }
    //改
    @Test
    public void updateObj(){
    	Query query = new Query();
        Update update = Update.update("value","python");
    	mongoTemplate.updateFirst(query, update, KeyValue.class);
    	mongoTemplate.updateMulti(query, update, KeyValue.class);
    }
    
    //查
    @Test
    public void getMongoValue(){
    	String key = "book";
    	KeyValue ret = mongoTemplate.findOne(new Query(Criteria.where("key").is(key)), KeyValue.class);
    	System.out.println(JSON.toJSONString(ret));
    }
    @Test
    public void getMongoValueListTest(){
    	String key = "book";
    	List<KeyValue> ret = mongoTemplate.find(new Query(Criteria.where("key").is(key)), KeyValue.class);
    	System.out.println(JSON.toJSONString(ret));
    }
    @Test
    public void getMongoCollectionNameTest(){
    	String ret = mongoTemplate.getCollectionName(KeyValue.class);
    	System.out.println(ret);
    }
	

}

下面是测试运行结果

1,测试新增

2,测试查询一条

3,测试查询列表

更多操作请参考官方文档

https://docs.spring.io/spring-data/mongodb/docs/current/api/org/springframework/data/mongodb/core/MongoTemplate.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值