NoSQL( Not Only SQL ),意思是」不只是SQL」。不同於傳統的關係型資料庫的資料庫管理系統的統稱。 NoSQL用於超大規模資料的儲存。這些類型的資料儲存不需要固定的模式,無需多餘操作即可橫向擴展。
--优点: 高可扩展性 分布式计算 低成本 架构的灵活性,半结构化数据 没有复杂的关系 --缺点: 没有标准化 有限的查询功能(到目前为止) 数据展现不直观
MongoDB 是介於關聯式資料庫和非關係資料庫之間的產品,是非關聯式資料庫當中,功能最豐富,最像關聯式資料庫的。他支援的資料結構非常鬆散,是類似 json 的 bjson 格式,因此可以儲存比較複雜的資料類型。 MongoDB 最大的特點是他支援的查詢語言非常強大,其語法有點類似於物件導向的查詢語言,幾乎可以實現類似關聯式資料庫單表查詢的絕大部分功能,而且還支援對資料建立索引。
1)MongoDB 是由C 語言編寫的,是一個基於分散式檔案儲存的開源資料庫系統。
2)在高負載的情況下,增加更多的節點,可以保證伺服器效能。
3)MongoDB 旨在為WEB應用提供可擴展的高效能資料儲存解決方案。
4)MongoDB 將資料儲存為一個文檔,資料結構由鍵值(key=>value)對組成。 MongoDB 文件類似於 JSON 物件。字段值可以包含其他文檔,數組及文檔數組。
# 打开命令行 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:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency>
#使用者名稱: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; @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); } }
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); } }
以上是SpringBoot2中如何配置MongoDB資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!