您当前的位置: 首页 >  mongodb

SpringBoot2 综合案例(11):集成MongoDB数据库,常用方法演示

蔚1 发布时间:2019-09-11 23:30:46 ,浏览量:1

Spring Boot 2 基础案例篇

包含:入门、日志管理、定时器、事务、AOP、数据库、缓存、NoSQL、监控、打包。

Spring Boot 2 高级案例篇

包含:整合常用中间件:分库分表、权限管理、Redis 集群、Dubbo、消息队列、定时器、搜索引擎、文件管理、邮件等

本文源码:GitHub·点这里 || GitEE·点这里

NoSQL 简介 NoSQL 概念

NoSQL( Not Only SQL ),意即"不仅仅是 SQL"。对不同于传统的关系型数据库的数据库管理系统的统称。NoSQL 用于超大规模数据的存储。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。

NoSQL 的优点/缺点
--优点:高可扩展性分布式计算低成本架构的灵活性,半结构化数据没有复杂的关系--缺点:没有标准化有限的查询功能(到目前为止)数据展现不直观
MongoDB 数据库 MongoDB 简介

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

MongoDB 特点

1)MongoDB 是由 C++语言编写的,是一个基于分布式文件存储的开源数据库系统。 2)在高负载的情况下,添加更多的节点,可以保证服务器性能。 3)MongoDB 旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。 4)MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。

与 SpringBoot2.0 整合 MongoDB 基础环境
# 打开命令行MongoDB4.0\bin>mongo# 展示所有数据库> show databases# 新建一个 admin 数据库,命令比较难为情> db.admin.insert({"name":"管理员数据库"});# 使用 admin 数据库> use admin# 创建 root 用户,具有读写权限> db.createUser({user:"root",pwd:"root",roles:[{role:"readWrite",db:"admin"}]})  Successfully added user:
核心依赖
    org.springframework.boot    spring-boot-starter-data-mongodb
配置文件

用户名:root密码:root数据库:admin

spring:  data:    mongodb:      uri: mongodb://root:root@localhost:27017/admin
封装应用接口
public interface ImgInfoRepository {    void saveImg(ImgInfo imgInfo) ;    ImgInfo findByImgTitle(String imgTitle);    long updateImgInfo(ImgInfo imgInfo) ;    void deleteById(Integer imgId);}
核心代码块

MongoDB 的使用方式如下。

import com.boot.mongodb.entity.ImgInfo;import com.boot.mongodb.repository.ImgInfoRepository;import com.mongodb.client.result.UpdateResult;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 org.springframework.stereotype.Service;import javax.annotation.Resource;@Servicepublic class ImgInfoRepositoryImpl implements ImgInfoRepository {    @Resource    private MongoTemplate mongoTemplate;    @Override    public void saveImg(ImgInfo imgInfo) {        mongoTemplate.save(imgInfo) ;    }    @Override    public ImgInfo findByImgTitle(String imgTitle) {        Query query=new Query(Criteria.where("imgTitle").is(imgTitle));        return mongoTemplate.findOne(query,ImgInfo.class);    }    @Override    public long updateImgInfo(ImgInfo imgInfo) {        Query query = new Query(Criteria.where("imgId").is(imgInfo.getImgId()));        Update update= new Update().set("imgTitle", imgInfo.getImgTitle()).set("imgUrl", imgInfo.getImgUrl());        UpdateResult result = mongoTemplate.updateFirst(query,update,ImgInfo.class);        return result.getMatchedCount();    }    @Override    public void deleteById(Integer imgId) {        Query query = new Query(Criteria.where("imgId").is(imgId));        mongoTemplate.remove(query,ImgInfo.class);    }}
测试代码块
import com.boot.mongodb.MongoDBApplication;import com.boot.mongodb.entity.ImgInfo;import com.boot.mongodb.repository.ImgInfoRepository;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import javax.annotation.Resource;import java.util.Date;@RunWith(SpringJUnit4ClassRunner.class)@SpringBootTest(classes = MongoDBApplication.class)public class MongoTest {    @Resource    private ImgInfoRepository imgInfoRepository ;    @Test    public void test1 (){        ImgInfo record = new ImgInfo() ;        record.setImgId(1);        record.setUploadUserId("A123");        record.setImgTitle("博文图片");        record.setSystemType(1) ;        record.setImgType(2);        record.setImgUrl("https://avatars0.githubusercontent.com/u/50793885?s=460&v=4");        record.setLinkUrl("https://avatars0.githubusercontent.com/u/50793885?s=460&v=4");        record.setShowState(1);        record.setCreateDate(new Date());        record.setUpdateDate(record.getCreateDate());        record.setRemark("知了");        record.setbEnable("1");        imgInfoRepository.saveImg(record);    }    @Test    public void test2 (){        ImgInfo imgInfo = imgInfoRepository.findByImgTitle("博文图片") ;        System.out.println("imgInfo === >> " + imgInfo);    }    @Test    public void test3 (){        ImgInfo record = new ImgInfo() ;        record.setImgId(1);        record.setUploadUserId("A123");        record.setImgTitle("知了图片");        record.setSystemType(1) ;        record.setImgType(2);        record.setImgUrl("https://avatars0.githubusercontent.com/u/50793885?s=460&v=4");        record.setLinkUrl("https://avatars0.githubusercontent.com/u/50793885?s=460&v=4");        record.setShowState(1);        record.setCreateDate(new Date());        record.setUpdateDate(record.getCreateDate());        record.setRemark("知了");        record.setbEnable("1");        long result = imgInfoRepository.updateImgInfo(record) ;        System.out.println("result == >> " + result);    }    @Test    public void test4 (){        imgInfoRepository.deleteById(1);    }}
源代码地址
GitHub·地址https://github.com/cicadasmile/spring-boot-baseGitEE·地址https://gitee.com/cicadasmile/spring-boot-base

本文首发于 GitChat,未经授权不得转载,转载需与 GitChat 联系。

阅读全文: http://gitbook.cn/gitchat/activity/5d790dfb6b96c1761863dabb

您还可以下载 CSDN 旗下精品原创内容社区 GitChat App ,阅读更多 GitChat 专享技术内容哦。

FtooAtPSkEJwnW-9xkCLqSTRpBKX

关注
打赏
1688896170
查看更多评论

蔚1

暂无认证

  • 1浏览

    0关注

    4645博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文
立即登录/注册

微信扫码登录

0.0576s