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

Mybatis參數(shù)傳遞示例代碼

 更新時(shí)間:2018年08月10日 11:15:21   作者:DaleZhang  
這篇文章主要給大家介紹了關(guān)于Mybatis參數(shù)傳遞的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

在實(shí)際開發(fā)中,大多數(shù)情況下都需要對 SQL 傳入?yún)?shù)以獲得想要的結(jié)果集,傳入的情況分為兩種情況:

1、SQL語句的拼接,比如表名、like 條件等;在 mybatis 中使用 ${} 包裹參數(shù),mybati 直接對其進(jìn)行字符串替換

2、SQL 中作為條件輸入的參數(shù),這種情況下,SQL 允許使用 ? 作為占位符來代替參數(shù),在 mybatis 中使用 #{} 包裹參數(shù),使用占位符有以下幾點(diǎn)好處:

  • mybatis 會對包裹的變量進(jìn)行轉(zhuǎn)義和類型檢查,避免以 SQL 注入的方式攻擊數(shù)據(jù)庫
  • 默認(rèn)情況下,mybatis 采用的是預(yù)編譯的方式,對于數(shù)據(jù)庫而言 SQL 本身沒有變化,變化的是傳入的參數(shù),數(shù)據(jù)庫只會編譯一次,而不會因?yàn)樽鳛闂l件的參數(shù)變化而重新編譯,節(jié)約了 SQL 執(zhí)行總時(shí)間

對于開發(fā)人員而言,能夠使用 #{} 傳入?yún)?shù)的情況都應(yīng)該采用這種形式。

傳入?yún)?shù)

接口 Mapper 傳入?yún)?shù)

在 xml 中寫 SQL 的時(shí)候注意到 parameterType 參數(shù),剛接觸的時(shí)候就有疑惑,如果有多個參數(shù)該如何指定。原來這是一個可選參數(shù),Mybatis 本身就可以通過 TypeHandler 推斷出具體傳入語句的參數(shù)。

總結(jié)通過接口方法傳入?yún)?shù)的情況:

  • 參數(shù)使用添加@Param注解,或者使用 '-parameters' 編譯選項(xiàng)并啟用 useActualParamName 選項(xiàng)(默認(rèn)開啟)來編譯項(xiàng)目
  • 特別的,如果參數(shù)是Javabean,在SQL中引用參數(shù)的時(shí)候可以直接使用屬性訪問符,而無需通過 get 方法。eg: #{Javabean.id}

配置文件傳入?yún)?shù)

有時(shí)候?yàn)榱藢⒈砻蛘?schema 可配置化,將變量寫到配置文件中,避免未來表名變化造成大的改動。

全局變量

首先如果是作為全局的參數(shù),可以將配置文件中的參數(shù)都寫入到 Javabean 中,使用的時(shí)候通過接口 Mapper 傳入即可。在 Spring 中

  • 在 Spring 配置文件中,使用 PropertiesFactoryBean 指定配置文件路徑,指定 id
  • 在 Javabean 文件中使用通過 @Value("#{id['name']}") 設(shè)置變量,并使用 @Component 注解該Javabean
  • 在接口 Mapper 中傳入該 Javabean

applicationContext.xml

 <bean id="exampleid" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
  <property name="locations">
   <array>
    <value>classpath:<name>.properties</value>
   </array>
  </property>
 </bean>

ExampleProperty.java

 @Component("exampleProperty")
 public class ExampleProperty {
 
  @Value("#{exampleid['name']}")
  public String name;
  ...
 }

引用

 @Resource
 private ExampleProperty exampleProperty;

只在 mybatis SQL 中引用

如果不是作為全局參數(shù),而只是在 SQL 中使用,則可以通過 mybatis 的配置文件 mybatis-config.xml 引入,這里引入的變量所有 SQL 的 xml 中都可以通過 ${} 的方式引入。

mybatis-config.xml

 <properties resource="<name>.properties">
  <property name="name" value="exampleName"/>
  <property name="id" value="exampleId"/>
  ...
 </properties>

參數(shù)加載的順序如下

  • 首先包裹的參數(shù)作為默認(rèn)值(推薦引入配置文件的同時(shí)也設(shè)定默認(rèn)參數(shù))
  • 加載 resource 中指定的配置文件,如果已指定了該參數(shù)則覆蓋
  • 如果通過接口 Mapper 傳入了同名參數(shù),接口 Mapper 傳入的參數(shù)覆蓋原有參數(shù)值

另外需要注意的是通過 mybatis-config.xml 設(shè)定的參數(shù),在 SQL 中無法直接使用 #{} 的方式引入,而有時(shí)候又想要用占位符的方式進(jìn)行預(yù)編譯,除了使用接口 Mapper 傳入?yún)?shù)外,還可以使用<bind>

bind 元素可以從 OGNL 表達(dá)式中創(chuàng)建一個變量并將其綁定到上下文

ExampleSQL.xml

 <mapper namespace="**.ExampleMapper">
  <select id="" resultType="string">
   <bind name="id" value="'${id}'"/>
   SELECT * FROM ××.×× 
   WHERE ID = #{id}
   ...
  </select>
 </mapper>

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • struts2框架的登錄制作圖文教程

    struts2框架的登錄制作圖文教程

    下面小編就為大家?guī)硪黄猻truts2框架的登錄制作圖文教程。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • SpringBoot集成Devtools實(shí)現(xiàn)熱更新

    SpringBoot集成Devtools實(shí)現(xiàn)熱更新

    DevTools是開發(fā)者工具集,主要用于簡化開發(fā)過程中的熱部署問題,熱部署是指在開發(fā)過程中,當(dāng)代碼發(fā)生變化時(shí),無需手動重啟應(yīng)用,系統(tǒng)能夠自動檢測并重新加載修改后的代碼,本文給大家介紹了SpringBoot集成Devtools實(shí)現(xiàn)熱更新,需要的朋友可以參考下
    2024-08-08
  • 在Spring Boot中集成RabbitMQ詳細(xì)步驟(最新推薦)

    在Spring Boot中集成RabbitMQ詳細(xì)步驟(最新推薦)

    本文將介紹如何在Spring Boot項(xiàng)目中集成RabbitMQ,實(shí)現(xiàn)生產(chǎn)者和消費(fèi)者的基本配置,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • java高并發(fā)InterruptedException異常引發(fā)思考

    java高并發(fā)InterruptedException異常引發(fā)思考

    這篇文章主要為大家介紹了java高并發(fā)InterruptedException異常引發(fā)思考,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Java 中校驗(yàn)時(shí)間格式的常見方法

    Java 中校驗(yàn)時(shí)間格式的常見方法

    在實(shí)際項(xiàng)目開發(fā)中,跟時(shí)間參數(shù)打交道是必不可少的,為了保證程序的安全性、健壯性,一般都會對參數(shù)進(jìn)行校驗(yàn),其他類型的參數(shù)校驗(yàn)很好實(shí)現(xiàn),那你知道時(shí)間參數(shù)的是怎么校驗(yàn)的嗎,下面給大家分享Java 中校驗(yàn)時(shí)間格式的方法,感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • log4j的配置文件詳細(xì)解析

    log4j的配置文件詳細(xì)解析

    以下小編主要為大家介紹一下log4j的配置文件各個配置項(xiàng)的含義。需要的朋友可以過來參考下
    2013-08-08
  • spring mvc配置bootstrap教程

    spring mvc配置bootstrap教程

    這篇文章主要為大家詳細(xì)介紹了spring mvc配置bootstrap,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Springboot 2使用外部Tomcat源碼分析

    Springboot 2使用外部Tomcat源碼分析

    這篇文章主要介紹了Springboot 2使用外部Tomcat源碼分析,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08
  • java實(shí)現(xiàn)乘地鐵方案的最優(yōu)選擇(票價(jià),距離)

    java實(shí)現(xiàn)乘地鐵方案的最優(yōu)選擇(票價(jià),距離)

    這篇文章主要介紹了java實(shí)現(xiàn)乘地鐵方案的最優(yōu)選擇(票價(jià),距離),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • ThreadLocal內(nèi)存泄漏常見要點(diǎn)解析

    ThreadLocal內(nèi)存泄漏常見要點(diǎn)解析

    這篇文章主要介紹了ThreadLocal內(nèi)存泄漏常見要點(diǎn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11

最新評論