springboot整合MongoDB

引言

springboot2.x已經集成了Mongodb了物舒,我們可以很方便的使用mongoTemplate獲取MongoDB中的數(shù)據(jù),但有時候光是MongoTemplate還不夠便捷贞言,我們完全可以根據(jù)需要做一些簡單的接口來簡化日常開發(fā)操作

引入jar

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

配置自定義的template

package com.wcf.mongo.config;

import com.mongodb.MongoClient;
import org.springframework.context.annotation.*;
import org.springframework.data.mongodb.MongoDbFactory;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.SimpleMongoDbFactory;


/**
 * @author wangcanfeng
 * @description 配置mongoDB的屬性
 * @Date Created in 11:13-2019/3/19
 */
@Configuration
public class WcfMongoAutoConfiguration {


    /**
     * 功能描述: 根據(jù)自己創(chuàng)建的工廠初始化一個template
     *
     * @param
     * @return:org.springframework.data.mongodb.core.MongoTemplate
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/21 14:23
     */
    @Bean
    @Primary
    public MongoTemplate template() {
        return new MongoTemplate(factory());
    }

    /**
     * 功能描述: 創(chuàng)建數(shù)據(jù)庫名稱對應的工廠,數(shù)據(jù)庫名稱可以通過配置文件導入
     *
     * @param
     * @return:org.springframework.data.mongodb.MongoDbFactory
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/21 14:22
     */
    @Bean("mongoDbFactory")
    public MongoDbFactory factory() {
        return new SimpleMongoDbFactory(client(), "test");
    }

    /**
     * 功能描述: 配置client阀蒂,client中傳入的ip和端口可以通過配置文件讀入
     *
     * @param
     * @return:com.mongodb.MongoClient
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/21 14:23
     */
    @Bean("mongoClient")
    public MongoClient client() {
        return new MongoClient("10.19.131.65", 7000);
    }

}

設置基礎的做一些簡單的業(yè)務過渡接口

package com.wcf.mongo.service;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.mongodb.client.ListIndexesIterable;
import com.mongodb.client.model.IndexOptions;
import com.mongodb.client.model.Indexes;
import com.wcf.mongo.entity.MongoBaseInfo;
import org.bson.Document;
import org.springframework.beans.factory.annotation.Autowired;
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 org.springframework.util.ObjectUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * @author wangcanfeng
 * @description 簡單的mongodb使用接口
 * @Date Created in 17:24-2019/3/20
 */
@Service
public class SimpleMongoServiceImpl<T extends MongoBaseInfo> implements SimpleMongoService<T> {

    /**
     * 注入template该窗,減少重復代碼
     */
    @Autowired
    private MongoTemplate mongoTemplate;


    /**
     * 功能描述: 創(chuàng)建一個集合
     * 同一個集合中可以存入多個不同類型的對象,我們?yōu)榱朔奖憔S護和提升性能脂新,
     * 后續(xù)將限制一個集合中存入的對象類型挪捕,即一個集合只能存放一個類型的數(shù)據(jù)
     *
     * @param name 集合名稱,相當于傳統(tǒng)數(shù)據(jù)庫的表名
     * @return:void
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 17:27
     */
    @Override
    public void createCollection(String name) {
        mongoTemplate.createCollection(name);
    }

    /**
     * 功能描述: 創(chuàng)建索引
     * 索引是順序排列争便,且唯一的索引
     *
     * @param collectionName 集合名稱级零,相當于關系型數(shù)據(jù)庫中的表名
     * @param filedName      對象中的某個屬性名
     * @return:java.lang.String
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 16:13
     */
    @Override
    public String createIndex(String collectionName, String filedName) {
        //配置索引選項
        IndexOptions options = new IndexOptions();
        // 設置為唯一
        options.unique(true);
        //創(chuàng)建按filedName升序排的索引
        return mongoTemplate.getCollection(collectionName).createIndex(Indexes.ascending(filedName), options);
    }


    /**
     * 功能描述: 獲取當前集合對應的所有索引的名稱
     *
     * @param collectionName
     * @return:java.util.List<java.lang.String>
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 16:46
     */
    @Override
    public List<String> getAllIndexes(String collectionName) {
        ListIndexesIterable<Document> list = mongoTemplate.getCollection(collectionName).listIndexes();
        //上面的list不能直接獲取size,因此初始化arrayList就不設置初始化大小了
        List<String> indexes = new ArrayList<>();
        for (Document document : list) {
            document.entrySet().forEach((key) -> {
                //提取出索引的名稱
                if (key.getKey().equals("name")) {
                    indexes.add(key.getValue().toString());
                }
            });
        }
        return indexes;
    }

    /**
     * 功能描述: 往對應的集合中插入一條數(shù)據(jù)
     *
     * @param info           存儲對象
     * @param collectionName 集合名稱
     * @return:void
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 16:46
     */
    @Override
    public void insert(T info, String collectionName) {
        mongoTemplate.insert(info, collectionName);
    }

    /**
     * 功能描述: 往對應的集合中批量插入數(shù)據(jù)滞乙,注意批量的數(shù)據(jù)中不要包含重復的id
     *
     * @param infos 對象列表
     * @return:void
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 16:47
     */
    @Override
    public void insertMulti(List<T> infos, String collectionName) {
        mongoTemplate.insert(infos, collectionName);
    }

    /**
     * 功能描述: 使用索引信息精確更改某條數(shù)據(jù)
     *
     * @param id             唯一鍵
     * @param collectionName 集合名稱
     * @param info           待更新的內容
     * @return:void
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 18:42
     */
    @Override
    public void updateById(String id, String collectionName, T info) {
        Query query = new Query(Criteria.where("id").is(id));
        Update update = new Update();
        String str = JSON.toJSONString(info);
        JSONObject jQuery = JSON.parseObject(str);
        jQuery.forEach((key, value) -> {
            //因為id相當于傳統(tǒng)數(shù)據(jù)庫中的主鍵奏纪,這里使用時就不支持更新,所以需要剔除掉
            if (!key.equals("id")) {
                update.set(key, value);
            }
        });
        mongoTemplate.updateMulti(query, update, info.getClass(), collectionName);
    }

    /**
     * 功能描述: 根據(jù)id刪除集合中的內容
     *
     * @param id             序列id
     * @param collectionName 集合名稱
     * @param clazz          集合中對象的類型
     * @return:void
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 16:47
     */
    @Override
    public void deleteById(String id, Class<T> clazz, String collectionName) {
        // 設置查詢條件斩启,當id=#{id}
        Query query = new Query(Criteria.where("id").is(id));
        // mongodb在刪除對象的時候會判斷對象類型序调,如果你不傳入對象類型,只傳入了集合名稱兔簇,它是找不到的
        // 上面我們?yōu)榱朔奖愎芾砗吞嵘罄m(xù)處理的性能发绢,將一個集合限制了一個對象類型,所以需要自行管理一下對象類型
        // 在接口傳入時需要同時傳入對象類型
        mongoTemplate.remove(query, clazz, collectionName);
    }

    /**
     * 功能描述: 根據(jù)id查詢信息
     *
     * @param id             注解
     * @param clazz          類型
     * @param collectionName 集合名稱
     * @return:java.util.List<T>
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/20 16:47
     */
    @Override
    public T selectById(String id, Class<T> clazz, String collectionName) {
        // 查詢對象的時候垄琐,不僅需要傳入id這個唯一鍵边酒,還需要傳入對象的類型,以及集合的名稱
        return mongoTemplate.findById(id, clazz, collectionName);
    }

    /**
     * 功能描述: 查詢列表信息
     * 將集合中符合對象類型的數(shù)據(jù)全部查詢出來
     *
     * @param collectName 集合名稱
     * @param clazz       類型
     * @return:java.util.List<T>
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/21 10:38
     */
    @Override
    public List<T> selectList(String collectName, Class<T> clazz) {
        return selectList(collectName, clazz, null, null);
    }

    /**
     * 功能描述: 分頁查詢列表信息
     *
     * @param collectName 集合名稱
     * @param clazz       對象類型
     * @param currentPage 當前頁碼
     * @param pageSize    分頁大小
     * @return:java.util.List<T>
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/21 10:38
     */
    @Override
    public List<T> selectList(String collectName, Class<T> clazz, Integer currentPage, Integer pageSize) {
        //設置分頁參數(shù)
        Query query = new Query();
        //設置分頁信息
        if (!ObjectUtils.isEmpty(currentPage) && ObjectUtils.isEmpty(pageSize)) {
            query.limit(pageSize);
            query.skip(pageSize * (currentPage - 1));
        }
        return mongoTemplate.find(query, clazz, collectName);
    }


    /**
     * 功能描述: 根據(jù)條件查詢集合
     *
     * @param collectName 集合名稱
     * @param conditions  查詢條件狸窘,目前查詢條件處理的比較簡單墩朦,僅僅做了相等匹配,沒有做模糊查詢等復雜匹配
     * @param clazz       對象類型
     * @param currentPage 當前頁碼
     * @param pageSize    分頁大小
     * @return:java.util.List<T>
     * @since: v1.0
     * @Author:wangcanfeng
     * @Date: 2019/3/21 10:48
     */
    @Override
    public List<T> selectByCondition(String collectName, Map<String, String> conditions, Class<T> clazz, Integer currentPage, Integer pageSize) {
        if (ObjectUtils.isEmpty(conditions)) {
            return selectList(collectName, clazz, currentPage, pageSize);
        } else {
            //設置分頁參數(shù)
            Query query = new Query();
            query.limit(pageSize);
            query.skip(currentPage);
            // 往query中注入查詢條件
            conditions.forEach((key, value) -> query.addCriteria(Criteria.where(key).is(value)));
            return mongoTemplate.find(query, clazz, collectName);
        }
    }
}

是不是很簡單的呢翻擒,如果有時間甚至可以封裝更好的業(yè)務接口

原創(chuàng)文章轉載請標明出處
更多文章請查看
http://www.canfeng.xyz

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末氓涣,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子陋气,更是在濱河造成了極大的恐慌劳吠,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恩伺,死亡現(xiàn)場離奇詭異赴背,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門凰荚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來燃观,“玉大人,你說我怎么就攤上這事便瑟±禄伲” “怎么了?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵到涂,是天一觀的道長脊框。 經常有香客問我,道長践啄,這世上最難降的妖魔是什么浇雹? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮屿讽,結果婚禮上昭灵,老公的妹妹穿的比我還像新娘。我一直安慰自己伐谈,他們只是感情好烂完,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著诵棵,像睡著了一般抠蚣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上履澳,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天嘶窄,我揣著相機與錄音,去河邊找鬼距贷。 笑死护侮,一個胖子當著我的面吹牛,可吹牛的內容都是我干的储耐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼滨溉,長吁一口氣:“原來是場噩夢啊……” “哼什湘!你這毒婦竟也來了?” 一聲冷哼從身側響起晦攒,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤闽撤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后脯颜,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哟旗,經...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了闸餐。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饱亮。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖舍沙,靈堂內的尸體忽然破棺而出近上,到底是詐尸還是另有隱情,我是刑警寧澤拂铡,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布壹无,位于F島的核電站,受9級特大地震影響感帅,放射性物質發(fā)生泄漏斗锭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一失球、第九天 我趴在偏房一處隱蔽的房頂上張望岖是。 院中可真熱鬧,春花似錦她倘、人聲如沸璧微。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽前硫。三九已至,卻和暖如春荧止,著一層夾襖步出監(jiān)牢的瞬間屹电,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工跃巡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留危号,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓素邪,卻偏偏與公主長得像外莲,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子兔朦,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內容