日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Boot 整合 MongoDB的示例

瀏覽:25日期:2023-08-05 16:29:22

本節(jié)使用SpringBoot 2.1.9.RELEASE,示例源碼在https://github.com/laolunsi/spring-boot-examples/tree/master/06-spring-boot-mongo-demo

SpringBoot可以非常方便地引入和操作MongoDB。本節(jié)分兩部分,記錄個人學(xué)習(xí)SpringBoot使用MongoDB數(shù)據(jù)庫的一些知識。

第一部分是一個簡單的springboot連接mongo的demo,測試查詢功能。

第二部分是基于mongo實現(xiàn)的增刪改查數(shù)據(jù)示例。

本節(jié)使用SpringBoot 2.1.9.RELEASE

一、A simple demo

首先來演示SpringBoot項目引入MongoDB,以及一個簡單的findAll操作。

maven依賴:

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

環(huán)境配置:

application.yml文件中寫入如下配置,test表示MongoDB中的test表

spring: data: mongodb: uri: 'mongodb://localhost:27017/test'

以一個bean類為例:

package com.example;public class User { private String id; private String name; private Integer age; private Integer grade; // ... ignore getter and setter // override its toString method @Override public String toString() { return 'User{' +'id=’' + id + ’’’ +', name=’' + name + ’’’ +', age=' + age +', grade=' + grade +’}’; }}

在MongoDB數(shù)據(jù)庫中新建一個collection(也就是表),名字叫user,插入幾條數(shù)據(jù),比如:

Spring Boot 整合 MongoDB的示例

注:這里用的可視化工具是robo 3t:https://www.jb51.net/database/567493.html

我們這里先默認(rèn)JavaBean的字段與user表的字段名保持一致。

下面我們編寫測試類:

@SpringBootTest@RunWith(SpringRunner.class)public class MongoTest { @Autowired private MongoTemplate mongoTemplate; @Test public void test1() { List<User> userList = mongoTemplate.findAll(User.class); if (userList != null && userList.size() > 0) { userList.forEach(user -> {System.out.println(user.toString()); }); } }}

運(yùn)行測試類,輸出如下:

User{id=’5d243534514701183f5fcab8’, name=’zf0’, age=12, grade=1}User{id=’5d243534514701183f5fcab9’, name=’zf1’, age=13, grade=2}User{id=’5d243534514701183f5fcaba’, name=’zf2’, age=14, grade=3}User{id=’5d243534514701183f5fcabb’, name=’zf3’, age=15, grade=4}User{id=’5d243534514701183f5fcabc’, name=’zf4’, age=16, grade=5}

二、基于SpringBoot的MongoDB增刪改查操作

下面來實現(xiàn)一個基于SpringBoot的對MongoDB增刪改查操作的簡單示例,依然使用上面的環(huán)境:

maven:

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope></dependency><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId></dependency><dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.60</version></dependency>

yml:

server: port: 8866spring: data: mongodb: uri: 'mongodb://localhost:27017/test'

User類:

這里我們清楚一下之前的數(shù)據(jù),把mongo里的user表里的數(shù)據(jù)全部刪掉。

Spring Boot 整合 MongoDB的示例

注:這里用的可視化工具admin-mongo:https://github.com/mrvautin/adminMongo

Spring Boot 整合 MongoDB的示例

新建一個不同的user類:

@Document('user')public class User { @Id private String id; @Field('name') private String name; @Field('password') private String password; @Field('address') private String address; @Field('create_time') private Date createTime; @Field('last_update_time') private Date lastUpdateTime; // ... ignore getter and setter methods @Override public String toString() { return JSONObject.toJSONString(this); }}

此處定義一個JsonResult類,用于封裝接口返回數(shù)據(jù):

import com.alibaba.fastjson.JSONObject;import java.util.HashMap;import java.util.Map;public class JsonResult { /** * 未登錄 */ public static final int NO_LOGIN = 400; /** * 登錄失敗 */ public static final int LOGIN_FAILED = 401; /** * TOKEN過期 */ public static final int TOKEN_EXPIRED = 402; /** * 無權(quán)限 */ public static final int NO_PERMISSION = 403; private Boolean success; private Integer code; private String msg; private Object data; public JsonResult(Boolean success) { this.success = success; } public JsonResult(Boolean success, String msg) { this.success = success; this.msg = msg; } public JsonResult(Integer code, Boolean success, String msg) { this.code = code; this.success = success; this.msg = msg; } public JsonResult(Boolean success, Object data) { this.success = success; this.data = data; } public JsonResult(Boolean success, Integer code, String msg, Object data) { this.success = success; this.code = code; this.msg = msg; this.data = data; } // ... ignore getter and setter methods public void put(String key, Object value) { if (data == null) { data = new HashMap<>(); } ((Map) data).put(key, value); } public void putAll(Map<String, Object> map) { if (data == null) { data = new HashMap<>(); } ((Map) data).putAll(map); } @Override public String toString() { return JSONObject.toJSONString(this); }}

下面編寫測試接口類,實現(xiàn)用戶的新增、刪除、更新、查詢功能

UserController類:

@RestController@RequestMapping(value = 'user')public class UserController { @Autowired private MongoTemplate mongoTemplate; @GetMapping(value = '') public JsonResult list() { List<User> userList = mongoTemplate.findAll(User.class, 'user'); return new JsonResult(true, userList); } @PostMapping(value = '') public JsonResult add(User user) { String msg = verifySaveForm(user); if (!StringUtils.isEmpty(msg)) { return new JsonResult(false, msg); } if (user.getId() == null) { user.setCreateTime(new Date()); user.setLastUpdateTime(new Date()); User newUser = mongoTemplate.insert(user, 'user'); return new JsonResult(true, newUser); } else { Query query = new Query(); query.addCriteria(Criteria.where('_id').is(user.getId())); Update update = new Update(); update.set('name', user.getName()); update.set('password', user.getPassword()); update.set('address', user.getAddress()); update.set('last_update_time', new Date()); UpdateResult updateResult = mongoTemplate.updateFirst(query, update, 'user'); return new JsonResult(true, updateResult); } } @DeleteMapping(value = '{id}') public JsonResult delete(@PathVariable String id) { Query query = new Query(); query.addCriteria(Criteria.where('_id').is(id)); DeleteResult deleteResult = mongoTemplate.remove(query, User.class, 'user'); return new JsonResult(true, deleteResult); } // private methods private String verifySaveForm(User user) { if (user == null || StringUtils.isEmpty(user.getName())) { return '用戶名不能為空'; } else if (user.getPassword() == null) { return '密碼不能為空'; } return null; }}

下面用postman模擬一下請求:

新增用戶:

Spring Boot 整合 MongoDB的示例

查看Mongodb:

Spring Boot 整合 MongoDB的示例

更改數(shù)據(jù),新增多個用戶:

Spring Boot 整合 MongoDB的示例

列表查詢:

Spring Boot 整合 MongoDB的示例

更改user:

Spring Boot 整合 MongoDB的示例

Spring Boot 整合 MongoDB的示例

刪除user:

Spring Boot 整合 MongoDB的示例

Spring Boot 整合 MongoDB的示例

好,到此為止,我們已經(jīng)在SpringBoot項目中引入了MongoDB,并實現(xiàn)了基本的增刪改查操作,這將是我們使用MongoDB開發(fā)更加復(fù)雜的業(yè)務(wù)的基礎(chǔ)!

以上就是Spring Boot 整合 MongoDB的示例的詳細(xì)內(nèi)容,更多關(guān)于Spring Boot 整合 MongoDB的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
中文亚洲免费| 午夜欧美视频| 麻豆精品蜜桃视频网站| 精品视频一区二区三区在线观看| 成人午夜在线| 欧美特黄一区| 中文字幕日韩亚洲| 久久国产人妖系列| 91亚洲一区| 伊人精品视频| 国产日韩一区二区三区在线播放 | 国产亚洲精aa在线看| 麻豆精品99| 国产99久久| 天堂va在线高清一区| 精品不卡一区| 欧美综合国产| 精品国产一区二区三区性色av| 久久精品99久久无色码中文字幕| 亚洲一区免费| 国产精品三p一区二区| 秋霞影院一区二区三区| 亚洲日本免费电影| 色网在线免费观看| 亚洲天堂日韩在线| 日韩欧美1区| 最新国产精品| 美女av在线免费看| 天海翼亚洲一区二区三区| 成人国产精选| 亚洲狼人精品一区二区三区| www.51av欧美视频 | 日韩精品亚洲专区| 精品精品久久| 麻豆精品网站| 91欧美日韩| 偷拍亚洲精品| 香蕉人人精品| 牛牛精品成人免费视频| 夜久久久久久| 国产一区二区精品福利地址| 中文一区一区三区免费在线观 | 欧美片第1页| 91精品日本| 五月天久久网站| 国际精品欧美精品| 日韩精品成人| 尹人成人综合网| 久久精品三级| 亚洲精品影视| 欧美在线资源| 91一区二区| 国产精品午夜一区二区三区| 国产精品日本欧美一区二区三区| а√天堂8资源在线| 亚洲精品一区二区妖精| 精品淫伦v久久水蜜桃| 亚洲精品九九| 国产精品av久久久久久麻豆网| 欧美激情视频一区二区三区免费 | 91精品国产成人观看| 国产精品一区二区三区av麻| 日韩中文字幕区一区有砖一区 | 亚洲1区在线观看| 激情婷婷久久| 国产精品精品| 国产精品极品| 日本久久二区| 亚洲一区二区三区久久久| 欧美成人日韩| 91精品国产自产观看在线| 六月丁香综合| 日韩视频免费| 99久久久久国产精品| 韩国女主播一区二区三区| 日韩精品一区二区三区中文在线| 亚洲综合丁香| 黄色av一区| 亚洲成人日韩| 久久中文字幕二区| 深夜视频一区二区| 久久久久久色| 亚洲精品日本| 视频在线观看国产精品| 亚洲成人三区| 亚洲黄色在线| 99国产精品视频免费观看一公开| 91精品韩国| 久草免费在线视频| 精品国产a一区二区三区v免费| 国产精品宾馆| 国产精品久久久久久妇女 | 免费国产亚洲视频| 日韩午夜高潮| 欧美在线资源| 日韩一区二区免费看| 夜夜嗨网站十八久久| 91久久黄色| 亚洲中字黄色| 亚洲乱亚洲高清| 青青伊人久久| 国产精品www.| 精品国产欧美日韩| 日韩精品欧美精品| 欧美日韩午夜电影网| 国产精品网在线观看| 国产美女亚洲精品7777| 欧美一级一区| 国产精品成人自拍| 日韩av在线播放网址| 国产精品久久久久av电视剧| 四虎884aa成人精品最新| 久久中文字幕av| 国产麻豆综合| 日韩成人午夜精品| 久久a爱视频| 国产福利片在线观看| 秋霞国产精品| 免费av一区二区三区四区| 伊人影院久久| 日韩在线观看一区二区三区| 国产精品一页| 精品国产乱码久久久| 欧美二三四区| 日韩视频一区二区三区在线播放免费观看 | 亚洲免费福利一区| 国产日韩欧美高清免费| 激情综合五月| 久久国产毛片| 日韩中文字幕亚洲一区二区va在线| 日本va欧美va精品发布| 精品国产午夜肉伦伦影院| 久久精品国产68国产精品亚洲| 欧美日韩四区| 日韩精品第一| 麻豆网站免费在线观看| 国产精品中文字幕制服诱惑| 久久久久免费| 噜噜噜久久亚洲精品国产品小说| 国产欧美丝祙| 日韩不卡视频在线观看| 亚洲一区二区免费在线观看| 你懂的亚洲视频| 激情偷拍久久| 国产日韩欧美中文在线| 日韩免费视频| 日韩在线黄色| 久久夜夜操妹子| 亚洲开心激情| 成人台湾亚洲精品一区二区| 影音先锋国产精品| 国产日韩欧美在线播放不卡| 日韩在线短视频| 亚洲综合福利| 中文字幕在线视频久| 亚洲视频电影在线| 国产夫妻在线| 日韩一区免费| 久久久夜夜夜| 久久国产欧美日韩精品| 久久婷婷一区| 国产乱码精品一区二区三区四区 | 美女久久99| 亚洲国产专区校园欧美| 奇米777国产一区国产二区| 日韩国产一区二区| 天海翼精品一区二区三区| 欧美日韩免费观看一区=区三区| 国产精品久久国产愉拍| 99pao成人国产永久免费视频| 国产精品尤物| 日韩视频不卡| 国产成人精品福利| 亚州av一区| 亚洲成av人片一区二区密柚| 久久精品xxxxx| 亚洲一区二区三区四区五区午夜| 国产成人精选| 日韩精品高清不卡| 狠狠爱成人网| 在线人成日本视频| 国产日韩视频在线| 模特精品在线| 久久精品在线| 老司机免费视频一区二区三区| 国产视频一区在线观看一区免费| 精品国产一级| 日本特黄久久久高潮| 亚洲免费在线| 久久精品免费一区二区三区 | 久久精品一本| 四虎国产精品免费久久| 欧美va天堂在线| 色婷婷色综合| 国产精品国码视频| 日韩欧美中文字幕在线视频| 日韩免费福利视频| 欧美黑人做爰爽爽爽| 97久久亚洲| 日韩中文字幕一区二区高清99|