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

小項目改造快速引入 mybatis的流程分析

 更新時間:2022年05月28日 10:43:29   作者:安逸的咸魚  
這篇文章主要介紹了小項目改造快速引入 mybatis,功能方面非常簡單,考慮到開發(fā)速度,直接按 springboot 項目進行開發(fā),依賴方面僅僅使用 spring-boot-starter-web, spring-boot-starter-jdbc, sqljdbc4, lombook,需要的朋友可以參考下

項目背景

項目在最開始,定位為一個插件、功能補充,為現(xiàn)有的 OA 提供一個報表功能,用于統(tǒng)計各個流程的數(shù)據(jù)

功能方面非常簡單,考慮到開發(fā)速度,直接按 springboot 項目進行開發(fā),依賴方面僅僅使用 spring-boot-starter-web, spring-boot-starter-jdbc, sqljdbc4, lombook

通過 @Bean 的方式注入 sql 查詢所需要的 JdbcTemplate 實例,后續(xù)的 sql 操作全部都以 template.queryForList(sqlStr) 的方式進行

由于忽略的 sql 上的復雜,加上 java8 尚未支持字符串模版,導致代碼中的 sql 類似于如下

閱讀、修改非常不便,決定還是引入 mybatis,最核心的訴求提高 sql 的可閱讀性,以及可維護性

開始改造

引入對應的 start

pom.xml 中添加 springboot 專用的 mybatis 依賴

<dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>2.2.2</version>
</dependency>

在 application.yml 中補充配置

主要是指定 mybatissql 所在的 xml 文件解析位置

mybatis:
  mapper-locations:
    - classpath:mybaits/*.xml

補充文件夾

項目的建議目錄排版如下:

|- src\main\java
    |- com.xx
        |- bean
        |- mapper
        xxxApplication
|- src\main\resources
    |- static
    |- mybaits
        |- Request.xml
    application.yml

xxxApplication 這個啟動類的同層,建立 mapper 文件夾,用于存放相關(guān)的 xxMapper 的接口文件。需要在接口上使用類注解 @Mapper 讓 mybatis 框架來識別。 代碼示例如下

@Mapper
public interface RequestMapper {
}

mybatis 文件夾下,存放與 xxMapper 相對應的 xml 文件

根據(jù) mybatis 官方文檔,可以得知用于存放 sql的標準 xml 文件格式如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.mybatis.example.BlogMapper">
  <select id="selectBlog" resultType="Blog">
    select * from Blog where id = #{id}
  </select>
</mapper>

我們需要修改 mapper 標簽中的 namespace 屬性,使之和我們的 xxMapper 對應;以同樣的格式補充新的 <select></select> 查詢語句

最后,將 通過 JdbcTemplate 執(zhí)行的 sql,規(guī)范為對應的 Mapper + xml 文件,并調(diào)整相關(guān)的函數(shù)調(diào)用,整個項目的改造就基本完成

總結(jié)

由于使用了 mybatis-spring-boot-starter 這個 start,加上我們遵循一些默認約定,只使用了一個配置就將 mybatis 應用到了這個項目上。這次改造中最大的變動就是將原 sql 處理為 xxMapper + xx.xml 兩種文件

可以欣賞一下,寫在 xml 中的 sql,是多么的優(yōu)雅

到此這篇關(guān)于小項目改造快速引入 mybatis的文章就介紹到這了,更多相關(guān)引入 mybatis內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springboot注入servlet的方法

    springboot注入servlet的方法

    本篇文章主要介紹了springboot注入servlet的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 基于kafka實現(xiàn)Spring Cloud Bus消息總線

    基于kafka實現(xiàn)Spring Cloud Bus消息總線

    消息總線是一種通信工具,可以在機器之間互相傳輸消息、文件等,這篇文章主要介紹了如何利用kafka實現(xiàn)SpringCloud Bus消息總線,感興趣的可以學習一下
    2022-04-04
  • java實現(xiàn)MD5加密的方法小結(jié)

    java實現(xiàn)MD5加密的方法小結(jié)

    這篇文章主要介紹了java實現(xiàn)MD5加密的方法,結(jié)合具體實例形式總結(jié)分析了java實現(xiàn)md5加密的常用操作技巧與使用方法,需要的朋友可以參考下
    2017-10-10
  • ZooKeeper官方文檔之Java案例解讀

    ZooKeeper官方文檔之Java案例解讀

    ZooKeeper官方提供了一個Java監(jiān)聽的例子,本文是我對該例子的學習筆記??梢宰鰹閹椭斫獯死拥馁Y料,有需要的朋友可以借鑒參考下
    2022-01-01
  • Java銀行取錢線程安全問題實例分析

    Java銀行取錢線程安全問題實例分析

    這篇文章主要介紹了Java銀行取錢線程安全問題,結(jié)合具體實例形式分析了java使用線程操作模擬銀行取錢的相關(guān)安全問題,需要的朋友可以參考下
    2019-09-09
  • Java中遍歷Map集合的5種方式總結(jié)

    Java中遍歷Map集合的5種方式總結(jié)

    這篇文章主要給大家介紹了關(guān)于Java中遍歷Map集合的5種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Java操作mongodb增刪改查的基本操作實戰(zhàn)指南

    Java操作mongodb增刪改查的基本操作實戰(zhàn)指南

    MongoDB是一個基于分布式文件存儲的數(shù)據(jù)庫,由c++語言編寫,旨在為WEB應用提供可擴展的高性能數(shù)據(jù)存儲解決方案,下面這篇文章主要給大家介紹了關(guān)于Java操作mongodb增刪改查的基本操作實戰(zhàn)指南,需要的朋友可以參考下
    2023-05-05
  • Java實現(xiàn)讀寫文件功能的代碼分享

    Java實現(xiàn)讀寫文件功能的代碼分享

    這篇文章主要為大家詳細介紹了如何利用Java語言實現(xiàn)讀寫文件功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2022-08-08
  • java學習之利用TCP實現(xiàn)的簡單聊天示例代碼

    java學習之利用TCP實現(xiàn)的簡單聊天示例代碼

    這篇文章主要給大家介紹了關(guān)于java學習筆記之利用TCP實現(xiàn)的簡單聊天的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-12-12
  • springboot+nginx+https+linux實現(xiàn)負載均衡加域名訪問簡單測試

    springboot+nginx+https+linux實現(xiàn)負載均衡加域名訪問簡單測試

    這篇文章主要介紹了springboot+nginx+https+linux實現(xiàn)負載均衡加域名訪問簡單測試,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-05-05

最新評論