欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis官方ORM框架比RedisTemplate更優(yōu)雅

 更新時間:2022年07月07日 16:41:14   作者:MacroZheng  
這篇文章主要為大家介紹了Redis官方ORM框架比RedisTemplate更優(yōu)雅的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

RedisOM簡介

之前在SpringBoot項目中,我一直使用RedisTemplate來操作Redis中的數據,這也是Spring官方支持的方式。對比Spring Data對MongoDB和ES的支持,這種使用Template的方式確實不夠優(yōu)雅!最近發(fā)現(xiàn)Redis官方新推出了Redis的專屬ORM框架RedisOM,用起來夠優(yōu)雅,推薦給大家!

SpringBoot實戰(zhàn)電商項目mall(50k+star)地址:github.com/macrozheng/…

RedisOM是Redis官方推出的ORM框架,是對Spring Data Redis的擴展。由于Redis目前已經支持原生JSON對象的存儲,之前使用RedisTemplate直接用字符串來存儲JOSN對象的方式明顯不夠優(yōu)雅。通過RedisOM我們不僅能夠以對象的形式來操作Redis中的數據,而且可以實現(xiàn)搜索功能!

JDK 11安裝

由于目前RedisOM僅支持JDK 11以上版本,我們在使用前得先安裝好它。

  • 然后在IDEA的項目配置中,將對應模塊的JDK依賴版本設置為JDK 11即可。

使用

接下來我們以管理存儲在Redis中的商品信息為例,實現(xiàn)商品搜索功能。注意安裝Redis的完全體版本RedisMod,具體可以參考RediSearch 使用教程 。

  • 首先在pom.xml中添加RedisOM相關依賴;
<!--Redis OM 相關依賴-->
<dependency>
    <groupId>com.redis.om</groupId>
    <artifactId>redis-om-spring</artifactId>
    <version>0.3.0-SNAPSHOT</version>
</dependency>
  • 由于RedisOM目前只有快照版本,還需添加快照倉庫;
<repositories>
    <repository>
        <id>snapshots-repo</id>
        <url>https://s01.oss.sonatype.org/content/repositories/snapshots/</url>
    </repository>
</repositories>
  • 然后在配置文件application.yml中添加Redis連接配置;
spring:
  redis:
    host: 192.168.3.105 # Redis服務器地址
    database: 0 # Redis數據庫索引(默認為0)
    port: 6379 # Redis服務器連接端口
    password: # Redis服務器連接密碼(默認為空)
    timeout: 3000ms # 連接超時時間
  • 之后在啟動類上添加@EnableRedisDocumentRepositories注解啟用RedisOM的文檔倉庫功能,并配置好文檔倉庫所在路徑;
@SpringBootApplication
@EnableRedisDocumentRepositories(basePackages = "com.macro.mall.tiny.*")
public class MallTinyApplication {

    public static void main(String[] args) {
        SpringApplication.run(MallTinyApplication.class, args);
    }

}
  • 然后創(chuàng)建商品的文檔對象,使用@Document注解標識其為文檔對象,由于我們的搜索信息中包含中文,我們需要設置語言為chinese;
/**
 * 商品實體類
 * Created by macro on 2021/10/12.
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Document(language = "chinese")
public class Product {
    @Id
    private Long id;
    @Indexed
    private String productSn;
    @Searchable
    private String name;
    @Searchable
    private String subTitle;
    @Indexed
    private String brandName;
    @Indexed
    private Integer price;
    @Indexed
    private Integer count;
}

分別介紹下代碼中幾個注解的作用;

  • @Id:聲明主鍵,RedisOM將會通過全類名:ID這樣的鍵來存儲數據;
  • @Indexed:聲明索引,通常用在非文本類型上;
  • @Searchable:聲明可以搜索的索引,通常用在文本類型上。

接下來創(chuàng)建一個文檔倉庫接口,繼承RedisDocumentRepository接口;

/**
 * 商品管理Repository
 * Created by macro on 2022/3/1.
 */
public interface ProductRepository extends RedisDocumentRepository&lt;Product, Long&gt; {
}
  • 創(chuàng)建測試用的Controller,通過Repository實現(xiàn)對Redis中數據的創(chuàng)建、刪除、查詢及分頁功能;
/**
 * 使用Redis OM管理商品
 * Created by macro on 2022/3/1.
 */
@RestController
@Api(tags = "ProductController", description = "使用Redis OM管理商品")
@RequestMapping("/product")
public class ProductController {

    @Autowired
    private ProductRepository productRepository;

    @ApiOperation("導入商品")
    @PostMapping("/import")
    public CommonResult importList() {
        productRepository.deleteAll();
        List&lt;Product&gt; productList = LocalJsonUtil.getListFromJson("json/products.json", Product.class);
        for (Product product : productList) {
            productRepository.save(product);
        }
        return CommonResult.success(null);
    }

    @ApiOperation("創(chuàng)建商品")
    @PostMapping("/create")
    public CommonResult create(@RequestBody Product entity) {
        productRepository.save(entity);
        return CommonResult.success(null);
    }

    @ApiOperation("刪除")
    @PostMapping("/delete/{id}")
    public CommonResult delete(@PathVariable Long id) {
        productRepository.deleteById(id);
        return CommonResult.success(null);
    }

    @ApiOperation("查詢單個")
    @GetMapping("/detail/{id}")
    public CommonResult&lt;Product&gt; detail(@PathVariable Long id) {
        Optional&lt;Product&gt; result = productRepository.findById(id);
        return CommonResult.success(result.orElse(null));
    }

    @ApiOperation("分頁查詢")
    @GetMapping("/page")
    public CommonResult&lt;List&lt;Product&gt;&gt; page(@RequestParam(defaultValue = "1") Integer pageNum,
                                            @RequestParam(defaultValue = "5") Integer pageSize) {
        Pageable pageable = PageRequest.of(pageNum - 1, pageSize);
        Page&lt;Product&gt; pageResult = productRepository.findAll(pageable);
        return CommonResult.success(pageResult.getContent());
    }

}
  • 當我們啟動項目時,可以發(fā)現(xiàn)RedisOM會自動為文檔建立索引;

  • 接下來我們訪問Swagger進行測試,先使用導入商品接口導入數據,訪問地址:http://localhost:8088/swagger-ui/

  • 導入成功后我們可以發(fā)現(xiàn)RedisOM已經向Redis中插入了原生JSON數據,以全類名:ID的形式命名了鍵,同時將全部的ID存儲到了一個SET集合中去了;

  • 我們可以通過ID來查詢商品信息;

  • 當然RedisOM也是支持衍生查詢的,通過我們創(chuàng)建的方法名稱就可以自動實現(xiàn)查詢邏輯,比如根據品牌名稱查詢商品,根據名稱和副標題關鍵字來搜索商品;
/**
 * 商品管理Repository
 * Created by macro on 2022/3/1.
 */
public interface ProductRepository extends RedisDocumentRepository&lt;Product, Long&gt; {
    /**
     * 根據品牌名稱查詢
     */
    List&lt;Product&gt; findByBrandName(String brandName);

    /**
     * 根據名稱或副標題搜索
     */
    List&lt;Product&gt; findByNameOrSubTitle(String name, String subTitle);
}
  • 在Controller中可以添加如下接口進行測試;
/**
 * 使用Redis OM管理商品
 * Created by macro on 2022/3/1.
 */
@RestController
@Api(tags = "ProductController", description = "使用Redis OM管理商品")
@RequestMapping("/product")
public class ProductController {

    @Autowired
    private ProductRepository productRepository;

    @ApiOperation("根據品牌查詢")
    @GetMapping("/getByBrandName")
    public CommonResult<List<Product>> getByBrandName(String brandName) {
        List<Product> resultList = productRepository.findByBrandName(brandName);
        return CommonResult.success(resultList);
    }

    @ApiOperation("根據名稱或副標題搜索")
    @GetMapping("/search")
    public CommonResult<List<Product>> search(String keyword) {
        List<Product> resultList = productRepository.findByNameOrSubTitle(keyword, keyword);
        return CommonResult.success(resultList);
    }

}
  • 我們可以通過品牌名稱來查詢商品;

  • 也可以通過關鍵字來搜索商品;

  • 這類根據方法名稱自動實現(xiàn)查詢邏輯的衍生查詢有什么規(guī)則呢,具體可以參考下表。

總結

今天體驗了一把RedisOM,用起來確實夠優(yōu)雅,和使用Spring Data來操作MongoDB和ES的方式差不多。不過目前RedisOM只發(fā)布了快照版本,期待Release版本的發(fā)布,而且Release版本據說會支持JDK 8的!

如果你想了解更多Redis實戰(zhàn)技巧的話,可以試試這個帶全套教程的實戰(zhàn)項目(50K+Star):github.com/macrozheng/…

參考資料

項目源碼地址github.com/macrozheng/…

以上就是Redis官方ORM框架比RedisTemplate更優(yōu)雅的詳細內容,更多關于Redis官方ORM框架的資料請關注腳本之家其它相關文章!

相關文章

  • Redis中哈希結構(Dict)的實現(xiàn)

    Redis中哈希結構(Dict)的實現(xiàn)

    本文主要介紹了Redis中哈希結構(Dict)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 深入解析Redis的LRU與LFU算法實現(xiàn)

    深入解析Redis的LRU與LFU算法實現(xiàn)

    這篇文章主要重點介紹了Redis的LRU與LFU算法實現(xiàn),并分析總結了兩種算法的實現(xiàn)效果以及存在的問題,并闡述其優(yōu)劣特性,感興趣的小伙伴跟著小編一起來看看吧
    2023-07-07
  • redis中key使用冒號分隔的原理小結

    redis中key使用冒號分隔的原理小結

    Redis是一種高性能的鍵值對非關系型數據庫,通過redis不同類型命令可以為其中的鍵指定不同的數據類型,其中每個鍵的命名規(guī)范通常使用冒號符號分隔字符串,本文主要介紹了redis中key使用冒號分隔的原理小結,感興趣的可以了解一下
    2024-01-01
  • Redis數據結構之intset整數集合使用學習

    Redis數據結構之intset整數集合使用學習

    這篇文章主要為大家介紹了Redis數據結構之整數集合使用學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • redis實現(xiàn)計數器-防止刷單方法介紹

    redis實現(xiàn)計數器-防止刷單方法介紹

    本文主要向大家介紹了redis實現(xiàn)計數器防止刷單的方法和有關代碼,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • Redis?異常?read?error?on?connection?的解決方案

    Redis?異常?read?error?on?connection?的解決方案

    這篇文章主要介紹了Redis異常read?error?on?connection的解決方案,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-08-08
  • 壓縮列表犧牲速度來節(jié)省內存,Redis是膨脹了嗎

    壓縮列表犧牲速度來節(jié)省內存,Redis是膨脹了嗎

    這篇文章主要給大家解釋了Redis 當中的 ziplist(壓縮列表)犧牲速度來節(jié)省內存的原因,希望大家能夠喜歡
    2021-02-02
  • Mac中Redis服務啟動時錯誤信息:NOAUTH Authentication required

    Mac中Redis服務啟動時錯誤信息:NOAUTH Authentication required

    這篇文章主要介紹了Mac中使用Redis服務啟動時錯誤信息:"NOAUTH Authentication required"問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 淺談Redis變慢的原因及排查方法

    淺談Redis變慢的原因及排查方法

    本文主要介紹了淺談Redis變慢的原因及排查方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Redis緩存的主要異常及解決方案實例

    Redis緩存的主要異常及解決方案實例

    這篇文章主要為大家介紹了Redis緩存的主要異常及解決方案實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01

最新評論