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
添加實體類
@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)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實現(xiàn)讀取163郵箱,qq郵箱的郵件內(nèi)容
這篇文章主要利用Java語言實現(xiàn)讀取163郵箱和qq郵箱的郵件內(nèi)容,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起動手試一試2022-02-02
SpringBoot集成支付寶沙箱支付的實現(xiàn)示例
本文主要介紹了SpringBoot集成支付寶沙箱支付的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12
Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別
這篇文章主要介紹了Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-08-08
使用Spring實現(xiàn)@Value注入靜態(tài)字段
這篇文章主要介紹了使用Spring實現(xiàn)@Value注入靜態(tài)字段方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05
Servlet關(guān)于RequestDispatcher的原理詳解
這篇文章主要介紹了Servlet關(guān)于RequestDispatcher的原理詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11

