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

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

SpringBoot整合MongoDB的示例

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

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

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

第一部分是一個(gè)簡(jiǎn)單的springboot連接mongo的demo,測(cè)試查詢功能。

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

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

一、A simple demo

首先來演示SpringBoot項(xiàng)目引入MongoDB,以及一個(gè)簡(jiǎn)單的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'

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

SpringBoot整合MongoDB的示例

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

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

下面我們編寫測(cè)試類:

@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)行測(cè)試類,輸出如下:

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

下面來實(shí)現(xiàn)一個(gè)基于SpringBoot的對(duì)MongoDB增刪改查操作的簡(jiǎn)單示例,依然使用上面的環(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ù)全部刪掉。

SpringBoot整合MongoDB的示例

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

SpringBoot整合MongoDB的示例

新建一個(gè)不同的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); }}

此處定義一個(gè)JsonResult類,用于封裝接口返回?cái)?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); }}

下面編寫測(cè)試接口類,實(shí)現(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模擬一下請(qǐng)求:

新增用戶:

SpringBoot整合MongoDB的示例

查看Mongodb:

SpringBoot整合MongoDB的示例

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

SpringBoot整合MongoDB的示例

列表查詢:

SpringBoot整合MongoDB的示例

更改user:

SpringBoot整合MongoDB的示例

SpringBoot整合MongoDB的示例

刪除user:

SpringBoot整合MongoDB的示例

SpringBoot整合MongoDB的示例

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

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩不卡一二三区| 蜜臀久久99精品久久久久久9| 蜜臀91精品一区二区三区| 丝袜亚洲精品中文字幕一区| 免费精品视频| 免费在线观看成人| 亚洲精品在线a| 日韩精品一区二区三区中文在线| 日本中文字幕不卡| 午夜天堂精品久久久久| 欧美在线精品一区| 国产精品欧美三级在线观看| 欧美激情麻豆| 国产一区二区三区国产精品| 91欧美在线| 欧美日韩水蜜桃| 亚洲免费影院| 日韩不卡一二三区| 国产精品久久久网站| 福利一区在线| 亚洲激情中文| 日韩中文字幕无砖| 国产精品观看| 在线天堂中文资源最新版| 天堂8中文在线最新版在线| 久久麻豆精品| 日韩精品一二区| 国产欧美日韩精品一区二区三区 | 欧美日韩国产亚洲一区| 亚洲免费在线| 国产欧美88| 成人av三级| 老司机久久99久久精品播放免费| 91欧美极品| 日韩欧美三级| 亚洲免费福利一区| 国产不卡一区| 红桃视频亚洲| 国产欧美另类| 亚洲韩日在线| 国产欧美一区二区三区米奇| 日韩欧美另类一区二区| 美美哒免费高清在线观看视频一区二区| 欧美日韩一区二区国产| 日韩欧美网址| 亚洲2区在线| 国产乱码午夜在线视频| 久久高清免费观看| 国精品产品一区| 男女精品网站| 精品中文字幕一区二区三区| 欧美午夜精彩| 日韩美女精品| 日本韩国欧美超级黄在线观看| 亚洲午夜国产成人| 色婷婷色综合| 日韩精品亚洲一区二区三区免费| 不卡一二三区| 日韩精品免费一区二区夜夜嗨| 日本黄色精品| 天堂精品久久久久| 亚洲综合电影| 日韩和欧美一区二区| 久久久精品五月天| 国产麻豆一区二区三区精品视频| 欧美~级网站不卡| 国产精品夜夜夜| 久久网站免费观看| 久久不见久久见免费视频7| 亚洲一区黄色| 日韩电影二区| 国产精品xxx在线观看| 亚洲激情黄色| 水蜜桃久久夜色精品一区| 日韩精品一区二区三区中文在线| 久久九九电影| 国产精品视频一区二区三区四蜜臂| 亚洲天堂黄色| 日韩av中文字幕一区| 午夜欧美精品| 亚洲天堂免费电影| 麻豆一区二区三| 日韩在线a电影| 99精品小视频| 欧美女激情福利| 亚洲1234区| 久久中文字幕一区二区| 日韩一区二区三区精品| 亚洲激情中文在线| 久久婷婷亚洲| 成人精品视频| 麻豆一区二区三| 欧美精品国产一区| 日韩欧美中文字幕一区二区三区| 国产精品毛片在线看| 亚洲手机在线| 亚洲精品.com| 大香伊人久久精品一区二区| 国产欧美日韩精品一区二区免费| 蜜臀va亚洲va欧美va天堂| 午夜久久tv| 精品在线91| 久久婷婷av| 亚洲电影有码| 日本久久成人网| sm久久捆绑调教精品一区| 老司机免费视频一区二区三区| 欧美日韩亚洲一区二区三区在线| 丝袜诱惑制服诱惑色一区在线观看| 亚洲特级毛片| 激情久久中文字幕| 国产一区亚洲| 久久久久久久久丰满| 午夜影院一区| av高清一区| 国产一区精品福利| 精品一区二区三区四区五区| 国产精品一区二区精品| 国产一精品一av一免费爽爽| 欧美亚洲自偷自偷| 欧美精品国产白浆久久久久| 欧美视频久久| 欧美交a欧美精品喷水| 国产伦理久久久久久妇女| 国产精品永久| 欧美韩一区二区| 欧美国产视频| 美女免费视频一区| 欧美激情aⅴ一区二区三区 | 日本成人手机在线| 午夜性色一区二区三区免费视频| 日韩一区精品| 国产欧美日韩一区二区三区在线| 国产精品久久久久久久久久久久久久久 | 福利在线免费视频| 福利视频一区| 日韩欧美国产精品综合嫩v| 三上悠亚国产精品一区二区三区| av综合电影网站| 91精品婷婷色在线观看| 日韩午夜精品| 日本国产欧美| 精品国产午夜| 欧美日韩在线二区| 999在线观看精品免费不卡网站| 日韩专区一卡二卡| 亚洲精品视频一二三区| 日韩成人午夜精品| 精品资源在线| 久久三级福利| 免费一级片91| 国产精品久久久久久久久久妞妞| 国产专区精品| 免费不卡中文字幕在线| 亚洲综合五月| 国产精品亚洲综合色区韩国| 97精品视频在线看| 宅男在线一区| 日韩一区二区三区四区五区| 国产调教一区二区三区| 精品国产美女a久久9999| 中国字幕a在线看韩国电影| 国产一区清纯| 日韩成人在线看| 日韩.com| 亚洲神马久久| 国产精品一区二区美女视频免费看| 成人在线免费观看网站| 在线看片不卡| 国产精品网址| 欧美亚洲国产精品久久| 亚洲人成网77777色在线播放| 国产精品极品在线观看| 久久久夜夜夜| 亚洲理论在线| 精品久久久网| 久久都是精品| 国内在线观看一区二区三区| 怡红院精品视频在线观看极品| 日韩国产91| 亚洲va中文在线播放免费| 在线看片一区| 国产一区二区三区四区五区传媒 | 视频一区二区国产| 久久影院资源站| 午夜一区在线| 国产福利片在线观看| 亚洲午夜免费| 福利一区二区三区视频在线观看| 亚洲欧美日韩在线观看a三区| 老牛国内精品亚洲成av人片| 在线一区视频| 国产aa精品| 日本亚洲不卡| 亚洲国内欧美| 久久精品三级| 亚洲精品伊人| 欧美日韩在线播放视频| 国产精品sss在线观看av| 午夜亚洲精品|