NoSQL可以极大提高互联网系统的性能,但是它有一些致命的缺陷,其中最为严重的就是计算功能卡分有限,例如,在一个10 万数据量的List 中,我只需要满足特定条件的元素在Red is 中,使用集合或者列表,你只有先把元素取出,然后才能通过条件筛选一个个得到你想要的数据,这显然存在比较大的问题

Reids中,对于那些需要缓存而且经常需要统计、分析和查询的数据, 显然就不是那么便捷。

这就需要MongoDB来实现了,需要统计、按条件查询和分析的数据,它提供了支持,它可以说是一个最接近于关系数据库的NoSQL 。

MongoDB的特点:将数据存储为一个文档,数据结构由键值( key-value )对组成。

这里的Mongo DB 文档类似于JSON 数据集,所以很容易转化成为Java POJO 对象或者JavaScript 对
象,这些字段值还可以包含其他文档、数组及文档数组

需要加入mongoDB-starter依赖

<!--加入mongodb依赖-->
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-mongodb -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
<version>2.3.2.RELEASE</version>
</dependency>

如果用到json的操作,还可以引入阿里巴巴的fastjson的开发包

springboot为我们自动创建的mongoDB的Bean:

向配置文件加入mongodb配置

编写一个和mongodb文档对应要存储的实体类:

@Document
public class User implements Serializable { private String id;
private String name;
private Integer age;
private Integer grade; 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 Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} public Integer getGrade() {
return grade;
} public void setGrade(Integer grade) {
this.grade = grade;
} @Override
public String toString() {
return "User{" +
"id='" + id + '\'' +
", name='" + name + '\'' +
", age=" + age +
", grade=" + grade +
'}';
}
}

可能使用的注解包括以下内容

@Id - 文档的唯一标识,在mongodb中为ObjectId,它是唯一的,通过时间戳+机器标识+进程ID+自增计数器
  (确保同一秒内产生的Id不会冲突)构成。 @Document - 把一个java类声明为mongodb的文档,可以通过collection参数指定这个类对应的文档。
      @Document(collection=“mongodb”) mongodb对应表 @DBRef - 声明类似于关系数据库的关联关系。ps:暂不支持级联的保存功能,当你在本实例中修改了DERef对象
    里面的值时,单独保存本实例并不能保存DERef引用的对象,
    它要另外保存,如下面例子的Person和Account。 @Indexed - 声明该字段需要索引,建索引可以大大的提高查询效率。 @CompoundIndex - 复合索引的声明,建复合索引可以有效地提高多字段的查询效率。 @GeoSpatialIndexed - 声明该字段为地理信息的索引。 @Transient - 映射忽略的字段,该字段不会保存到mongodb。 @PersistenceConstructor - 声明构造函数,作用是把从数据库取出的数据实例化为对象。

 注意:因为数据库的规范采用下划线分隔,二java一般采用驼峰式命名,所以可以使用@Field进行设置

指定该属性在mongodb里面使用的保存名字 

插入一条记录:

cotroller:

  @Autowired
UserService service; //http://localhost:8988/insert?id=110&name=quan&age=222&grade=223
@RequestMapping("/insert")
public User insertUser(User user){
// User user = new User();
// user.setAge(23);
//
// user.setGrade(98);
// user.setName("quqquq");
service.insertUser(user);
return user;
}

UserService接口:

public interface UserService {
public void insertUser(User user);

UserServiceImpl接口:

注意:这里需要标注@Service和定义扫描的包,spring才会将它自动装配进来

MongoTemplate不需要自己创建,只需要在配置文件中配置和mongo'db相关内容就行

@Service
public class UserServiceImpl implements UserService{
@Autowired
private MongoTemplate mongoTemplate; @Override
public void insertUser(User user) {
mongoTemplate.insert(user);
}

注意:mongoTemplate.save(user) 也是可以进行mongodb的存储的。

save和insert的区别:

若增加的数据的主键已经存在,insert会抛出一个主键重复的异常。不会保存数据

而save会直接对已经存在的数据进行修改。

删除:

    public DeleteResult deleteUser(String id);
    /**
* 1使用主键构建出一个准则,
* 2使用MongoTemplate的remove方法进行删除操作
* 3返回一个DeleteResult对象,记录此次操作记录。
* 属性deletedCount代表删除文档的条数
* @param id
* @return
*/
    @Override
public DeleteResult deleteUser(String id) {
Criteria criteria = Criteria.where("id").is(id);
Query query = Query.query(criteria);
DeleteResult result =mongoTemplate.remove(query,User.class);
return result;
}

注意:使用remove方法的时候,需要指定文档对应的实体类的class

    @RequestMapping("/delUser/{id}")
public DeleteResult delUser(@PathVariable("id") String id){
return service.deleteUser(id);
}

更新:

    /**
* 1通过构建Query对象确认更新什么内容,这里使用主键确认对应的文档
* 2定义一个更新对象,定义的时候同时设置了对username的更新
* 3通过更新对象的set方法设置相关内容的更新
* 4使用MongoTemplate执行更新。
* 注意:有两个更新方法,updateFirst(只执行第一个确定对象) updateMulti(执行所有确定对象)
* 5更新方法的返回值:
* "matchedCount": Query对象匹配的文档数
* "modifiedCount": 被更新的文档数
* "upsertedId": 如果存在更新而插入文档的情况返回插入文档的信息
* @param user
* @return
*/

这里只给出实现类的方法:

    @Override
public UpdateResult upUser(User user) {
Criteria criteria = Criteria.where("id").is(user.getId());
Query query = Query.query(criteria);
//定义更新对象,随便更新name;
Update update = Update.update("name",user.getName());
update.set("age",user.getAge());
update.set("grade",user.getGrade()); UpdateResult updateResult = mongoTemplate.updateFirst(query,update,User.class);
return updateResult;
}

一开始:

请求之后:

结果:

spring-boot-learning-MongoDB的更多相关文章

  1. springboot(十一):Spring boot中mongodb的使用

    mongodb是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多.由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 MongoDB 因配置 ...

  2. (转)Spring Boot(十一):Spring Boot 中 MongoDB 的使用

    http://www.ityouknow.com/springboot/2017/05/08/spring-boot-mongodb.html MongoDB 是最早热门非关系数据库的之一,使用也比较 ...

  3. Spring Boot(十一):Spring Boot 中 MongoDB 的使用

    MongoDB 是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多.由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 MongoDB 因配 ...

  4. 使用spring boot访问mongodb数据库

    一. spring boot中传参的方法 1.自动化配置 spring Boot 对于开发人员最大的好处在于可以对 Spring 应用进行自动配置.Spring Boot 会根据应用中声明的第三方依赖 ...

  5. MongoDB最简单的入门教程之四:使用Spring Boot操作MongoDB

    Spring Boot 是一个轻量级框架,可以完成基于 Spring 的应用程序的大部分配置工作.Spring Boot的目的是提供一组工具,以便快速构建容易配置的Spring应用程序,省去大量传统S ...

  6. Spring Boot开发MongoDB应用实践

    本文继续上一篇定时任务中提到的邮件服务,简单讲解Spring Boot中如何使用MongoDB进行应用开发. 上文中提到的这个简易邮件系统大致设计思路如下: 1.发送邮件支持同步和异步发送两种 2.邮 ...

  7. spring boot(十一)MongoDB的使用

    mongodb是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多.由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 MongoDB 因配置 ...

  8. SpringBoot(十一):Spring boot 中 mongodb 的使用

    原文出处: 纯洁的微笑 mongodb是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多.由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 ...

  9. 记一次spring boot中MongoDB Prematurely reached end of stream的异常解决

    在spring boot项目中使用了mongodb,当一段时间没有操作mongodb,下次操作mongodb时就会出现异常.异常如下: org.springframework.data.mongodb ...

  10. Spring boot整合Mongodb

    最近的项目用了Mongodb,网上的用法大多都是七零八落的没有一个统一性,自己大概整理了下,项目中的相关配置就不叙述了,由于spring boot的快捷开发方式,所以spring boot项目中要使用 ...

随机推荐

  1. 软件性能测试分析与调优实践之路-Java应用程序的性能分析与调优-手稿节选

    Java编程语言自从诞生起,就成为了一门非常流行的编程语言,覆盖了互联网.安卓应用.后端应用.大数据等很多技术领域,因此Java应用程序的性能分析和调优也是一门非常重要的课题.Java应用程序的性能直 ...

  2. 自助BI工具:Tableau和Smartbi的对比(下)

    上一篇我们已经将Tableau和Smartbi的自助功能分析了一部分,本文已3个重要的因素进行对比.分别从数据处理.数据可视化以及性价比方面进行分析.我们一起来看看这两个平台是各方面怎么样,帮助大家挑 ...

  3. idea导入hadoop jar包

    hadoop jar包 在hadoop安装目录下,找到share\hadoop目录,搜索jar,全选,然后在安装目录新建_jar文件夹,将所有的jar包拷进去 idea添加jar包 在Project ...

  4. javascript中逻辑运算符&&和||的返回值问题

    今天在做逻辑运算符的时候遇到一个小问题一直转不过弯来,var a=(undefined&&123)||(3||5)的返回值是什么? 首先是||的返回值问题: ||的返回值会返回最早遇到 ...

  5. 微服务从代码到k8s部署应有尽有系列(十、错误处理)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  6. Cloud Computing Chapter3 (云计算第三章)

    本篇文章是对课程大型软件系统设计与体系结构(双语)[又名:云计算]的课堂内容总结,适用于大连交通大学. Cloud Computing Chapter3 Understanding Cloud Com ...

  7. laravel 框架登录 参考

    一.登录功能1.书写登录路由Route::view('login','login');2.书写登录页面  视图层<form action="{{route('loginDo')}}&q ...

  8. 使用pip安装扩展包

    pip可以对python扩展包进行查找.下载.安装.卸载等

  9. python学习之numpy实战

    import numpy as np def main(): lst=[[1,3,5],[2,4,6]] print('hello world') print(type(lst)) np_lst = ...

  10. WPF中Enter 焦点转移方法

    1.Set the TabIndex="16"2. private void detailGrid_Keydown(object sender, KeyEventArgs e) { ...