MongoDB常用的CRUD(MongoTemplate實(shí)現(xiàn))

上一篇文章已經(jīng)講了如何去動(dòng)態(tài)注入一個(gè)MongoTemplate,接下來(lái)我來(lái)給大家演示如何使用MongoTemplate完成常用的CRUD

公司之前用的是舊的mongoClient,不能直接操作對(duì)象,MongoTemplate正好彌補(bǔ)了這個(gè)不足,分享給大家

準(zhǔn)備PO對(duì)象

import org.springframework.data.mongodb.core.index.Indexed;
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.mongodb.core.mapping.Field;

/**
 * @author mr_h
 * @createTime 2017/9/25
 * @description //TODO
 */
@Document(collection = "collection_name")
public class UserPO {
    @Indexed
    @Field("user_id")
    private Long userId;

    @Field("username")
    private String username;

    @Field("password")
    private String password;




    public Long getUserId() {
        return userId;
    }

    public void setUserId(Long userId) {
        this.userId = userId;
    }

    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;
    }
}

解釋

  • @Document 用來(lái)表明關(guān)聯(lián)的mongo中的那個(gè)collection(類似于表名)
  • @Indexed 為某個(gè)字段建立索引
  • @Field 聲明屬性對(duì)應(yīng)的數(shù)據(jù)庫(kù)中的哪個(gè)字段

--------------------------------開始操作----------------------------------

插入數(shù)據(jù)
//插入一條
        UserPO userPO = new UserPO();
        userPO.setUserId(1L);
        userPO.setUsername("username");
        userPO.setPassword("password");
        mongoTemplate.insert(userPO);

//插入多條
        LinkedList<UserPO> pos = Lists.newLinkedList();
        UserPO userPO = new UserPO();
        userPO.setUserId(1L);
        userPO.setUsername("username");
        userPO.setPassword("password");
        pos.add(userPO);//集合中可以放多個(gè)
        mongoTemplate.insertAll(pos);
刪除數(shù)據(jù)
image.png

可以看到有多種刪除方法,我們?cè)谶@里演示一個(gè)相對(duì)復(fù)雜的

Query query = new Query();
        query.addCriteria(Criteria.where("user_id").is(1L));
        mongoTemplate.findAndRemove(query,UserPO.class);
  • Query是查詢條件
更改數(shù)據(jù)
image.png
image.png

更改的API大概有這些

  • updateMulti 如果根據(jù)查詢條件找到對(duì)應(yīng)的多條記錄是,全部更新
  • updateFirst 更改符合條件的第一個(gè)
  • upsert 顧名思義 update+insert 如果根據(jù)條件沒(méi)有對(duì)應(yīng)的數(shù)據(jù),則執(zhí)行插入
  • findAndModify 查詢?nèi)缓蟾?/li>

接下來(lái)演示比較復(fù)雜的findAndModify

Query query = new Query();
        query.addCriteria(Criteria.where("user_id").is(1L));
        Update update = new Update();
        update.set("username","the new username");
        mongoTemplate.findAndModify(query,update,UserPO.class);
查詢

其實(shí)看到這里 應(yīng)該查詢就不需要看了,因?yàn)樯厦娲蟛糠盅菔镜亩际窍炔樵內(nèi)缓笤偃ゲ僮鬟@條數(shù)據(jù)

Query query = new Query();
        query.addCriteria(Criteria.where("user_id").is(1L));
        List<UserPO> userPOS = mongoTemplate.find(query, UserPO.class);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • MySQL技術(shù)內(nèi)幕:InnoDB存儲(chǔ)引擎(第2版) 姜承堯 第1章 MySQL體系結(jié)構(gòu)和存儲(chǔ)引擎 >> 在上述例子...
    沉默劍士閱讀 7,642評(píng)論 0 16
  • B樹的定義 一棵m階的B樹滿足下列條件: 樹中每個(gè)結(jié)點(diǎn)至多有m個(gè)孩子。 除根結(jié)點(diǎn)和葉子結(jié)點(diǎn)外,其它每個(gè)結(jié)點(diǎn)至少有m...
    文檔隨手記閱讀 13,682評(píng)論 0 25
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,568評(píng)論 19 139
  • NoSql數(shù)據(jù)庫(kù)優(yōu)缺點(diǎn) 在優(yōu)勢(shì)方面主要體現(xiàn)在下面幾點(diǎn): 簡(jiǎn)單的擴(kuò)展 快速的讀寫 低廉的成本 靈活的數(shù)據(jù)模型 在不足...
    dreamer_lk閱讀 2,875評(píng)論 0 6
  • 二十九歲,是一個(gè)尷尬的年紀(jì) 堅(jiān)持還是放棄,是一個(gè)問(wèn)題 明明有才華有身材有顏值生活精致 可是形單影只 就足以抵消所有...
    pan朵閱讀 362評(píng)論 5 15

友情鏈接更多精彩內(nèi)容