一、NoSQL簡介
1、NoSQL 概念
NoSQL( Not Only SQL ),意即"不僅僅是SQL"。對不同于傳統的關系型資料庫的資料庫管理系統的統稱。NoSQL用于超大規模資料的存儲。這些類型的資料存儲不需要固定的模式,無需多餘操作就可以橫向擴充。
2、NoSQL的優點/缺點
--優點:
高可擴充性
分布式計算
低成本
架構的靈活性,半結構化資料
沒有複雜的關系
--缺點:
沒有标準化
有限的查詢功能(到目前為止)
資料展現不直覺
二、MongoDB資料庫
1、MongoDB簡介
MongoDB 是一個介于關系資料庫和非關系資料庫之間的産品,是非關系資料庫當中功能最豐富,最像關系資料庫的。他支援的資料結構非常松散,是類似 json 的 bjson 格式,是以可以存儲比較複雜的資料類型。MongoDB 最大的特點是他支援的查詢語言非常強大,其文法有點類似于面向對象的查詢語言,幾乎可以實作類似關系資料庫單表查詢的絕大部分功能,而且還支援對資料建立索引。
2、MongoDB特點
1)MongoDB 是由C++語言編寫的,是一個基于分布式檔案存儲的開源資料庫系統。
2)在高負載的情況下,添加更多的節點,可以保證伺服器性能。
3)MongoDB 旨在為WEB應用提供可擴充的高性能資料存儲解決方案。
4)MongoDB 将資料存儲為一個文檔,資料結構由鍵值(key=>value)對組成。MongoDB 文檔類似于 JSON 對象。字段值可以包含其他文檔,數組及文檔數組。
三、與SpringBoot2.0整合
1、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:
2、核心依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
3、配置檔案
使用者名:root
密碼:root
資料庫:admin
spring:
data:
mongodb:
uri: mongodb://root:root@localhost:27017/admin
4、封裝應用接口
public interface ImgInfoRepository {
void saveImg(ImgInfo imgInfo) ;
ImgInfo findByImgTitle(String imgTitle);
long updateImgInfo(ImgInfo imgInfo) ;
void deleteById(Integer imgId);
}
5、核心代碼塊
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;
@Service
public 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);
}
}
6、測試代碼塊
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-base
碼雲位址:知了一笑
https://gitee.com/cicadasmile/spring-boot-base