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

您的位置:首頁技術文章
文章詳情頁

SpringBoot整合MongoDB的示例

瀏覽:24日期:2023-04-13 11:42:08

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

SpringBoot可以非常方便地引入和操作MongoDB。本節分兩部分,記錄個人學習SpringBoot使用MongoDB數據庫的一些知識。

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

第二部分是基于mongo實現的增刪改查數據示例。

本節使用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>

環境配置:

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數據庫中新建一個collection(也就是表),名字叫user,插入幾條數據,比如:

SpringBoot整合MongoDB的示例

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

我們這里先默認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()); }); } }}

運行測試類,輸出如下:

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增刪改查操作

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

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類:

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

SpringBoot整合MongoDB的示例

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

SpringBoot整合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類,用于封裝接口返回數據:

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; /** * 無權限 */ 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); }}

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

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模擬一下請求:

新增用戶:

SpringBoot整合MongoDB的示例

查看Mongodb:

SpringBoot整合MongoDB的示例

更改數據,新增多個用戶:

SpringBoot整合MongoDB的示例

列表查詢:

SpringBoot整合MongoDB的示例

更改user:

SpringBoot整合MongoDB的示例

SpringBoot整合MongoDB的示例

刪除user:

SpringBoot整合MongoDB的示例

SpringBoot整合MongoDB的示例

以上就是SpringBoot整合MongoDB的示例的詳細內容,更多關于SpringBoot整合MongoDB的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
手机精品视频在线观看| 亚洲h色精品| 91久久视频| 狠狠爱成人网| 91精品99| 精品91久久久久| 国产精品嫩草99av在线| 国产手机视频一区二区| 亚洲精品一区二区在线看| 国产专区一区| 日韩亚洲国产欧美| 热久久免费视频| 日韩欧美激情电影| 香蕉久久国产| 午夜久久av| 国产精品一线| 久久精品一区二区三区中文字幕| 欧美极品一区二区三区| 国产一区二区三区探花| 日韩精品麻豆| 91精品二区| 日韩精品电影一区亚洲| 国产欧美大片| 国产一区二区三区成人欧美日韩在线观看| 久久久久久婷| 五月天久久久| 亚洲精品日本| 九九久久国产| 成人看片网站| 日韩影院免费视频| 欧美在线日韩| 国产+成+人+亚洲欧洲在线| 日韩欧美一区二区三区在线观看| 不卡在线一区二区| 日韩精品视频在线看| 国产精品久久久久久久久久妞妞| 精品黄色一级片| 亚洲精品一二三区区别| 日韩高清国产一区在线| 久久97久久97精品免视看秋霞| 亚洲播播91| 蜜桃久久久久久| 久久中文字幕一区二区三区| 91精品韩国| 亚洲久久一区| 国产成人精品一区二区三区视频| 在线观看免费一区二区| 日韩激情视频网站| 97国产精品| 国产精品女主播一区二区三区| 欧美一区成人| 日韩精品欧美| 欧美日韩一区二区三区不卡视频 | 欧美一级精品| 日韩影院免费视频| 国产成人免费| 亚洲精品伊人| 日韩电影免费网址| 婷婷五月色综合香五月| 亚洲精品福利电影| 中文字幕日韩亚洲| 亚洲天堂av影院| 无码日韩精品一区二区免费| 精品入口麻豆88视频| 久久最新视频| 国产精品久久久久久久免费观看| 免播放器亚洲一区| 午夜av不卡| 欧美日韩一区二区三区不卡视频| 人人精品亚洲| 国产精品一区二区三区av麻| 欧美日韩国产探花| 精品国内亚洲2022精品成人 | 欧美日韩国产高清| 精品亚洲成人| 亚洲欧美日本国产| 婷婷精品视频| 蜜桃久久久久| 亚洲永久精品唐人导航网址| av一区在线| 欧美aⅴ一区二区三区视频| 日韩中文字幕区一区有砖一区| 中文在线资源| 欧美亚洲自偷自偷| 亚洲一级淫片| 亚洲国内欧美| 麻豆视频在线看| 欧美国产亚洲精品| 日韩av中文字幕一区二区三区| 一区二区亚洲精品| 天堂日韩电影| 国产一区二区精品福利地址| 久久国产生活片100| 蜜臀av在线播放一区二区三区| 国产在线成人| 在线看片国产福利你懂的| 久久wwww| 91福利精品在线观看| 91久久亚洲| 久久久久久黄| 国产精品福利在线观看播放| 欧美午夜三级| 亚洲开心激情| 99成人在线| 亚洲二区在线| 蜜臀久久精品| 欧美sm一区| 久久青青视频| 黄在线观看免费网站ktv| 国产精品欧美三级在线观看| 日韩精品视频网站| 亚州欧美在线| 中文精品电影| 在线午夜精品| 国产精品99一区二区| 群体交乱之放荡娇妻一区二区| 日韩av二区| 国产精品99久久精品| 精品国产aⅴ| 国产福利亚洲| 精品99在线| 国产在线看片免费视频在线观看| 国产suv精品一区二区四区视频| 麻豆成人91精品二区三区| 国产精品66| 狂野欧美性猛交xxxx| 国产一区福利| 日韩精品欧美激情一区二区| 91免费精品| 成人美女视频| 91精品久久久久久久久久不卡| 神马日本精品| 尹人成人综合网| 蜜桃久久精品一区二区| 午夜电影一区| 六月丁香综合在线视频| 欧美国产美女| 久久久久网站| 视频一区欧美日韩| 日韩欧美中文字幕在线视频| 国产日韩一区二区三免费高清| 国产精品xvideos88| 国产伊人久久| 99精品在线| 尤物在线精品| 午夜久久av | 欧美专区18| 亚州精品视频| 免费在线亚洲| 日韩中文首页| 五月精品视频| 日本在线成人| 欧美自拍一区| 精品视频97| 久久人人精品| 蜜臀av一区二区在线免费观看| 欧美一区自拍| 色一区二区三区四区| 国产一在线精品一区在线观看| 日韩专区一卡二卡| 国产精品亚洲一区二区在线观看| 国产999精品在线观看| 欧美日韩一二三四| 日本一区二区三区中文字幕| 免费一级欧美在线观看视频| 久久精品动漫| 亚洲另类黄色| 久久精品欧洲| 精品91久久久久| 国产精品伊人| 欧美二区视频| 欧美一区二区三区免费看| 欧美日韩国产观看视频| 视频一区在线播放| 精品久久福利| 天堂av在线一区| 久久99国产精品视频| 亚洲欧洲一区| 国产精品天天看天天狠| 日韩免费小视频| 日韩国产在线一| 色爱av综合网| 青青草精品视频| 国产一区二区三区视频在线| 亚洲一区不卡| 欧美精品97| 久久先锋影音| 波多视频一区| 日本不卡一区二区| 99久久夜色精品国产亚洲狼| 欧美一区=区三区| 米奇777超碰欧美日韩亚洲| 国产乱码精品| 亚洲一区二区三区四区五区午夜| 麻豆精品视频在线| 日韩精品一区第一页| 成人在线视频中文字幕| 亚洲免费一区三区| 国产精品99视频| 青草综合视频|