SpringBoot訪問MongoDB數(shù)據(jù)庫的兩種方式
spring-data-mongodb提供了MongoTemplate和MongoRepository兩種方式訪問MongoDB,MongoRepository的方式訪問較為簡單,MongoTemplate方式較為靈活,這兩種方式在Java對于MongoDB的運(yùn)用中相輔相成。
一、基于MongoTemplate開發(fā)
引入依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> </dependency>
修改yml配置
spring:
data:
mongodb:
#192.168.217.128根據(jù)自己的ip進(jìn)行修改
#test是MongoDB的集合名稱 也就是表名
uri: mongodb://192.168.217.128:27017/test
添加實(shí)體類
@Data @AllArgsConstructor @Document("User") //指定了這個模型類型所對應(yīng)的集合名稱即collection 表名 public class User { @Id //自動生成的主鍵ID 主鍵 不可重復(fù) 自帶索引 private String id; private String name; private Integer age; }
方法測試
@SpringBootTest public class MongoTemplateTest { @Autowired private MongoTemplate mongoTemplate; @Test public void testMongoDB(){ //向表中插入數(shù)據(jù) User user = new User(null,"張三",20); User user1 = new User(null,"李四",16); mongoTemplate.insert(user); mongoTemplate.insert(user1); //查詢表中所有記錄 List<User> userList = mongoTemplate.findAll(User.class); System.out.println(userList); //[User(id=63acf541e6af652ac74fd008, name=張三, age=20), // User(id=63acf541e6af652ac74fd009, name=李四, age=16)] //根據(jù)表中id查詢記錄 User user2 = mongoTemplate.findById("63acf541e6af652ac74fd008", User.class); System.out.println(user2);//User(id=63acf541e6af652ac74fd008, name=張三, age=20) //條件查詢 Query query = new Query(Criteria.where("name").is("李四").and("age").is(16)); List<User> users = mongoTemplate.find(query, User.class); System.out.println(users);//[User(id=63acf541e6af652ac74fd009, name=李四, age=16)] //根據(jù)_id刪除表中記錄 Query query2 = new Query(Criteria.where("_id").is("63acf541e6af652ac74fd008")); DeleteResult remove = mongoTemplate.remove(query2, User.class); //獲取刪除記錄的個數(shù) long count = remove.getDeletedCount(); System.out.println(count);//1 //刪除表中所有數(shù)據(jù) Query query3 = new Query(); mongoTemplate.remove(query3,User.class); } }
二、基于MongoRepository開發(fā)
Spring Data提供了對MongoDB數(shù)據(jù)訪問的支持,我們只需要繼承MongoRepository類,按照Spring Data規(guī)范就可以了。
構(gòu)建倉庫
public interface UserRepository extends MongoRepository<User,String> { }
方法測試
@SpringBootTest public class MongoRepositoryTest { @Autowired private UserRepository userRepository; @Test public void test(){ //向數(shù)據(jù)庫表中插入數(shù)據(jù) User user = new User(null,"張三三",18); User user1 = new User(null,"李四",16); userRepository.save(user); userRepository.save(user1); //查詢數(shù)據(jù)庫表中所有記錄 List<User> all = userRepository.findAll(); System.out.println(all); //[User(id=63acf24938e0d1033d50dc20, name=張三三, age=18), // User(id=63acf24938e0d1033d50dc21, name=李四, age=16)] //按照id查詢表中數(shù)據(jù) User user2 = userRepository.findById("63acf24938e0d1033d50dc20").get(); System.out.println(user2);//User(id=63acf24938e0d1033d50dc20, name=張三三, age=18) //按條件(姓名與年齡)查詢 Example<User> example = Example.of(new User(null,"李四",16)); List<User> list = userRepository.findAll(example); System.out.println(list);//User(id=63acf24938e0d1033d50dc21, name=李四, age=16) //模糊查詢 User user3 = new User(null,"三",18); //模糊查詢匹配規(guī)則 ExampleMatcher matcher = ExampleMatcher.matching() .withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING) .withIgnoreCase(true);//忽略大小寫 Example<User> example1 = Example.of(user3,matcher); List<User> list1 = userRepository.findAll(example1); System.out.println(list1);//User(id=63acf24938e0d1033d50dc20, name=張三三, age=18) //分頁查詢 Pageable pageable = PageRequest.of(0, 2);//設(shè)置分頁參數(shù):第1頁 每頁2條數(shù)據(jù) Page<User> page = userRepository.findAll(pageable); System.out.println("Page的總頁數(shù)是:" + page.getTotalPages() + ",Page的總記錄條數(shù)是:" + page.getTotalElements()); //Page的總頁數(shù)是:1 + ,Page的總記錄條數(shù)是:2 //根據(jù)_id修改信息 User user4 = userRepository.findById("63acf24938e0d1033d50dc20").get(); user4.setName("王五");//將取出的信息修改其name userRepository.save(user4); //根據(jù)id刪除 userRepository.deleteById("63acf24938e0d1033d50dc20"); //刪除全部 userRepository.deleteAll(); } }
到此這篇關(guān)于SpringBoot訪問MongoDB數(shù)據(jù)庫的兩種方式的文章就介紹到這了,更多相關(guān)SpringBoot訪問MongoDB內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot使用MyBatis-Flex實(shí)現(xiàn)靈活的數(shù)據(jù)庫訪問
- SpringBoot中使用JdbcTemplate訪問Oracle數(shù)據(jù)庫的案例詳解
- SpringBoot整合數(shù)據(jù)庫訪問層的實(shí)戰(zhàn)
- SpringBoot使用JdbcTemplate訪問操作數(shù)據(jù)庫基本用法
- SpringBoot快速整合Mybatis、MybatisPlus(代碼生成器)實(shí)現(xiàn)數(shù)據(jù)庫訪問功能
- SpringBoot如何訪問不同的數(shù)據(jù)庫的方法實(shí)現(xiàn)
相關(guān)文章
Java實(shí)現(xiàn)讀取163郵箱,qq郵箱的郵件內(nèi)容
這篇文章主要利用Java語言實(shí)現(xiàn)讀取163郵箱和qq郵箱的郵件內(nèi)容,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起動手試一試2022-02-02SpringBoot集成支付寶沙箱支付的實(shí)現(xiàn)示例
本文主要介紹了SpringBoot集成支付寶沙箱支付的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別
這篇文章主要介紹了Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-08-08使用Spring實(shí)現(xiàn)@Value注入靜態(tài)字段
這篇文章主要介紹了使用Spring實(shí)現(xiàn)@Value注入靜態(tài)字段方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05Servlet關(guān)于RequestDispatcher的原理詳解
這篇文章主要介紹了Servlet關(guān)于RequestDispatcher的原理詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11