溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

發(fā)布時(shí)間:2022-05-13 13:46:24 來源:億速云 閱讀:278 作者:iii 欄目:開發(fā)技術(shù)

今天小編給大家分享一下SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

一、什么是MongoDB

MongoDB與我們之前熟知的關(guān)系型數(shù)據(jù)庫MySQL、Oracle)不同,MongoDB是一個(gè)文檔數(shù)據(jù)庫,它具有所需的可伸縮性和靈活性,以及所需的查詢和索引。

MongoDB將數(shù)據(jù)存儲(chǔ)在靈活的、類似JSON的文檔中,這意味著文檔的字段可能因文檔而異,數(shù)據(jù)結(jié)構(gòu)也會(huì)隨著時(shí)間的推移而改變。文檔模型映射到應(yīng)用程序代碼中的對象,使數(shù)據(jù)易于處理。MongoDB是一個(gè)以分布式數(shù)據(jù)庫為核心的數(shù)據(jù)庫,因此高可用性、橫向擴(kuò)展和地理分布是內(nèi)置的,并且易于使用。況且,MongoDB是免費(fèi)的,開源的。

二、在Window10上安裝MongoDB

打開MongoDB官網(wǎng)

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

下載MSI版本(安裝版)

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

下載的時(shí)候選擇Custom

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

安裝的時(shí)候,注意不要勾上安裝可視化插件,否則安裝會(huì)非常慢(除非你網(wǎng)速夠快)

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

三、配置MongoDB服務(wù)

配置環(huán)境變量

復(fù)制當(dāng)前路徑

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

我的電腦->右鍵->高級(jí)系統(tǒng)設(shè)置->環(huán)境變量->系統(tǒng)變量

在系統(tǒng)變量找到Path,編輯,將上面復(fù)制的路徑增加進(jìn)去

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

四、啟動(dòng)服務(wù)

win+R->輸入services.msc

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

服務(wù)啟動(dòng)后,在瀏覽器輸入 127.0.0.1:2701

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

出現(xiàn)這行英語則代表服務(wù)啟動(dòng)成功。

五、SpringBoot整合MongoDB

環(huán)境準(zhǔn)備

操作系統(tǒng):Window10

IDE:IntelliJ IDEA 2018.2.4

數(shù)據(jù)庫:MongoDB

1)引入依賴

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>

2)在application.yml添加如下配置

spring:
  data:
    mongodb:
      uri: mongodb://localhost/test_mongodb

完整的配置信息如下:

spring:
  data:
    mongodb:
      authentication-database: # Authentication database name.
      database: # Database name.
      field-naming-strategy: # Fully qualified name of the FieldNamingStrategy to use.
      grid-fs-database: # GridFS database name.
      host: # Mongo server host. Cannot be set with URI.
      password: # Login password of the mongo server. Cannot be set with URI.
      port: # Mongo server port. Cannot be set with URI.
      repositories:
        type: # Type of Mongo repositories to enable.
      uri: # Mongo database URI. Cannot be set with host, port and credentials.
      username: # Login user of the mongo server. Cannot be set with URI.

3)新增實(shí)體類UserEntity

public class UserEntity {
    @Id
    private String uid;
    private String username;
    private String password;
    public String getUid() {
        return uid;
    }
    public void setUid(String uid) {
        this.uid = uid;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    @Override
    public String toString() {
        return "UserEntity{" +
                "uid='" + uid + '\'' +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

4)新建測試。這里我用navicat作為MongoDB的可視化工具進(jìn)行查看。

測試一:插入操作

    @Autowired
    private MongoTemplate mongoTemplate;
    @Test
    public void saveUser(){
        UserEntity userEntity1 = new UserEntity();
        UserEntity userEntity2 = new UserEntity();
        UserEntity userEntity3 = new UserEntity();
        userEntity1.setUid("111");
        userEntity1.setUsername("用戶1");
        userEntity1.setPassword("密碼1");
        userEntity2.setUid("222");
        userEntity2.setUsername("用戶2");
        userEntity2.setPassword("密碼2");
        userEntity3.setUid("333");
        userEntity3.setUsername("用戶3");
        userEntity3.setPassword("密碼3");
        mongoTemplate.save(userEntity1);
        mongoTemplate.save(userEntity2);
        mongoTemplate.save(userEntity3);
    }

數(shù)據(jù)庫信息:

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

可以看到,MongoDB自動(dòng)創(chuàng)建了數(shù)據(jù)庫以及通過實(shí)體類生成了集合(也就是我們經(jīng)常說的數(shù)據(jù)表),而且我們已經(jīng)通過MongoTemplate往數(shù)據(jù)庫的userEntity集合插入了幾條文檔(也就是插入了幾條記錄)。而 _id 為主鍵,_class 則為實(shí)體類包名+類名

測試二:查詢操作

    @Autowired
    private MongoTemplate mongoTemplate;
	@Test
    public void findUserByUserName(){
        String username = "用戶1";
        Query query=new Query(Criteria.where("username").is(username));
        UserEntity user =  mongoTemplate.findOne(query , UserEntity.class);
        System.out.println(user);
    }

輸出結(jié)果:

UserEntity{uid='111', username='用戶1', password='密碼1'}

測試三:更新操作

  @Autowired
    private MongoTemplate mongoTemplate;    
	@Test
    public void updateUser(){
        UserEntity userEntity = new UserEntity();
        userEntity.setUid("111");
        userEntity.setUsername("更新后的用戶名");
        userEntity.setPassword("更新后的密碼");
        Query query = new Query(Criteria.where("_id").is(userEntity.getUid()));
        Update update = Update.update("username",userEntity.getUsername()).set("password",userEntity.getPassword());
        //更新返回結(jié)果集的第一條
        mongoTemplate.updateFirst(query,update,UserEntity.class);
        //更新返回結(jié)果集的所有
        //mongoTemplate.updateMulti(query,update,UserEntity.class);
    }

更新后數(shù)據(jù)庫如圖所示:

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

測試四:刪除操作

    @Autowired
    private MongoTemplate mongoTemplate; 
	@Test
    public  void DeleteByUserId(){
        String id = "222";
        Query query=new Query(Criteria.where("_id").is(id));
        mongoTemplate.remove(query,UserEntity.class);
    }

刪除后數(shù)據(jù)庫如圖所示:

SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改

以上就是“SpringBoot怎么整合Mongodb實(shí)現(xiàn)增刪查改”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI