亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot訪問(wèn)MongoDB數(shù)據(jù)庫(kù)的兩種方式

 更新時(shí)間:2023年05月20日 09:18:18   作者:小白的救贖  
MongoDB是一種非關(guān)系型數(shù)據(jù)庫(kù),通過(guò)文檔存儲(chǔ)數(shù)據(jù),適用于大規(guī)模數(shù)據(jù)存儲(chǔ)和高并發(fā)訪問(wèn),這篇文章主要介紹了SpringBoot訪問(wèn)MongoDB數(shù)據(jù)庫(kù)的兩種方式,感興趣想要詳細(xì)了解可以參考下文

spring-data-mongodb提供了MongoTemplate和MongoRepository兩種方式訪問(wèn)MongoDB,MongoRepository的方式訪問(wèn)較為簡(jiǎn)單,MongoTemplate方式較為靈活,這兩種方式在Java對(duì)于MongoDB的運(yùn)用中相輔相成。

一、基于MongoTemplate開(kāi)發(fā)

引入依賴(lài)

<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的集合名稱(chēng) 也就是表名
      uri: mongodb://192.168.217.128:27017/test

添加實(shí)體類(lèi)

@Data
@AllArgsConstructor
@Document("User") //指定了這個(gè)模型類(lèi)型所對(duì)應(yīng)的集合名稱(chēng)即collection 表名
public class User {
    @Id //自動(dòng)生成的主鍵ID 主鍵 不可重復(fù) 自帶索引
    private String id;
    private String name;
    private Integer age;
}

方法測(cè)試

@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);
        //獲取刪除記錄的個(gè)數(shù)
        long count = remove.getDeletedCount();
        System.out.println(count);//1
        //刪除表中所有數(shù)據(jù)
        Query query3 = new Query();
        mongoTemplate.remove(query3,User.class);
    }
}

二、基于MongoRepository開(kāi)發(fā)

Spring Data提供了對(duì)MongoDB數(shù)據(jù)訪問(wèn)的支持,我們只需要繼承MongoRepository類(lèi),按照Spring Data規(guī)范就可以了。

構(gòu)建倉(cāng)庫(kù)

public interface UserRepository extends MongoRepository<User,String> {
}

方法測(cè)試

@SpringBootTest
public class MongoRepositoryTest {
    @Autowired
    private UserRepository userRepository;
    @Test
    public void test(){
        //向數(shù)據(jù)庫(kù)表中插入數(shù)據(jù)
        User user = new User(null,"張三三",18);
        User user1 = new User(null,"李四",16);
        userRepository.save(user);
        userRepository.save(user1);
        //查詢數(shù)據(jù)庫(kù)表中所有記錄
        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);//忽略大小寫(xiě)
        Example<User> example1 = Example.of(user3,matcher);
        List<User> list1 = userRepository.findAll(example1);
        System.out.println(list1);//User(id=63acf24938e0d1033d50dc20, name=張三三, age=18)
        //分頁(yè)查詢
        Pageable pageable = PageRequest.of(0, 2);//設(shè)置分頁(yè)參數(shù):第1頁(yè) 每頁(yè)2條數(shù)據(jù)
        Page<User> page = userRepository.findAll(pageable);
        System.out.println("Page的總頁(yè)數(shù)是:" + page.getTotalPages() + ",Page的總記錄條數(shù)是:" + page.getTotalElements());
        //Page的總頁(yè)數(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訪問(wèn)MongoDB數(shù)據(jù)庫(kù)的兩種方式的文章就介紹到這了,更多相關(guān)SpringBoot訪問(wèn)MongoDB內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java實(shí)現(xiàn)讀取163郵箱,qq郵箱的郵件內(nèi)容

    Java實(shí)現(xiàn)讀取163郵箱,qq郵箱的郵件內(nèi)容

    這篇文章主要利用Java語(yǔ)言實(shí)現(xiàn)讀取163郵箱和qq郵箱的郵件內(nèi)容,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起動(dòng)手試一試
    2022-02-02
  • SpringBoot集成支付寶沙箱支付的實(shí)現(xiàn)示例

    SpringBoot集成支付寶沙箱支付的實(shí)現(xiàn)示例

    本文主要介紹了SpringBoot集成支付寶沙箱支付的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Java中JSON處理工具類(lèi)使用詳解

    Java中JSON處理工具類(lèi)使用詳解

    這篇文章主要為大家詳細(xì)介紹了Java中JSON處理工具類(lèi)的使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 基于JavaMail的Java郵件發(fā)送

    基于JavaMail的Java郵件發(fā)送

    電子郵件的應(yīng)用非常廣泛,例如在某網(wǎng)站注冊(cè)了一個(gè)賬戶,自動(dòng)發(fā)送一封歡迎郵件,通過(guò)郵件找回密碼,自動(dòng)批量發(fā)送活動(dòng)信息等。本文將簡(jiǎn)單介紹如何通過(guò) Java 代碼來(lái)創(chuàng)建電子郵件,并連接郵件服務(wù)器發(fā)送郵件
    2021-10-10
  • Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別

    Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別

    這篇文章主要介紹了Java?Spring?Dubbo三種SPI機(jī)制的區(qū)別,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-08-08
  • java結(jié)合HADOOP集群文件上傳下載

    java結(jié)合HADOOP集群文件上傳下載

    這篇文章主要介紹了java結(jié)合HADOOP集群文件上傳下載的方法和示例,非常的實(shí)用,這里推薦給大家,希望大家能夠喜歡。
    2015-03-03
  • idea運(yùn)行jsp文件的時(shí)候顯示404問(wèn)題及解決

    idea運(yùn)行jsp文件的時(shí)候顯示404問(wèn)題及解決

    這篇文章主要介紹了idea運(yùn)行jsp文件的時(shí)候顯示404問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • java實(shí)現(xiàn)Base64加密解密算法

    java實(shí)現(xiàn)Base64加密解密算法

    Base64用來(lái)將非ASCII字符的數(shù)據(jù)轉(zhuǎn)換成ASCII字符的一種方法,這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)Base64加密解密算法,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 使用Spring實(shí)現(xiàn)@Value注入靜態(tài)字段

    使用Spring實(shí)現(xiàn)@Value注入靜態(tài)字段

    這篇文章主要介紹了使用Spring實(shí)現(xiàn)@Value注入靜態(tài)字段方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Servlet關(guān)于RequestDispatcher的原理詳解

    Servlet關(guān)于RequestDispatcher的原理詳解

    這篇文章主要介紹了Servlet關(guān)于RequestDispatcher的原理詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11

最新評(píng)論