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

MyBatis  Properties及別名定義實(shí)例詳解

 更新時(shí)間:2017年08月08日 09:17:53   作者:YSOcean  
這篇文章主要介紹了MyBatis Properties及別名定義實(shí)例詳解,需要的朋友可以參考下

上一篇我們介紹了mybatis的增刪改查入門實(shí)例,我們發(fā)現(xiàn)在 mybatis-configuration.xml 的配置文件中,對數(shù)據(jù)庫的配置都是硬編碼在這個(gè)xml文件中,如下圖,那么我們?nèi)绾胃倪M(jìn)這個(gè)寫法呢?

1、我們將 數(shù)據(jù)庫的配置語句寫在 db.properties 文件中

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm
jdbc.username=root
jdbc.password=root

2、在  mybatis-configuration.xml 中加載db.properties文件并讀取

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 加載數(shù)據(jù)庫屬性文件 -->
<properties resource="db.properties">
</properties>
 <environments default="development">
 <environment id="development">
 <transactionManager type="JDBC"/>
 <!--dataSource 元素使用標(biāo)準(zhǔn)的 JDBC 數(shù)據(jù)源接口來配置 JDBC 連接對象源 -->
 <dataSource type="POOLED">
 <property name="driver" value="${jdbc.driver}"/>
 <property name="url" value="${jdbc.url}"/>
 <property name="username" value="${jdbc.username}"/>
 <property name="password" value="${jdbc.password}"/>
 </dataSource>
 </environment>
 </environments>
</configuration>

  如果數(shù)據(jù)庫有變化,我們就可以通過修改 db.properties 文件來修改,而不用去修改 mybatis-configuration.xml 文件

注意:我們也可以在<properties></properties>中手動(dòng)增加屬性

<!-- 加載數(shù)據(jù)庫屬性文件 -->
<properties resource="db.properties">
 <property name="username" value="aaa"/>
</properties>

  那么這個(gè)時(shí)候是讀取的username 是以 db.properties 文件中的 root 為準(zhǔn),還是以自己配置的 aaa 為準(zhǔn)呢?

我們先看一段 properties 文件加載的源碼

private void propertiesElement(XNode context) throws Exception {
 if (context != null) {
 /**
 * 解析properties 屬性中指定的屬性。
 */
 Properties defaults = context.getChildrenAsProperties();
 String resource = context.getStringAttribute("resource"); //resource 制定的屬性路徑
 String url = context.getStringAttribute("url"); //url制定的屬性路徑
 if (resource != null && url != null) {
 throw new BuilderException("The properties element cannot specify both a URL and a resource based property file reference. Please specify one or the other.");
 }
 /**
 * 根據(jù) properties 元素中的 resource 屬性讀取類路徑下屬性文件,并覆蓋properties 屬性中指定的同名屬性。
 */
 if (resource != null) {
 defaults.putAll(Resources.getResourceAsProperties(resource));
 } else if (url != null) {
 /**
 * 根據(jù)properties元素中的url屬性指定的路徑讀取屬性文件,并覆蓋properties 屬性中指定的同名屬性。
 */
 defaults.putAll(Resources.getUrlAsProperties(url));
 }
 /**
 * 獲取方法參數(shù)傳遞的properties
 * 創(chuàng)建XMLConfigBuilder實(shí)例時(shí),this.configuration.setVariables(props);
 */
 Properties vars = configuration.getVariables();
 if (vars != null) {
 defaults.putAll(vars);
 }
 parser.setVariables(defaults);
 configuration.setVariables(defaults);
 }
}

通過源碼我們可以分析讀取優(yōu)先級(jí):

    1、在 properties 內(nèi)部自定義的屬性值第一個(gè)被讀取

    2、然后讀取 resource 路徑表示文件中的屬性,如果有它會(huì)覆蓋已經(jīng)讀取的屬性;如果 resource 路徑不存在,那么讀取 url 表示路徑文件中的屬性,如果有它會(huì)覆蓋第一步讀取的屬性值

    3、最后讀取 parameterType 傳遞的屬性值,它會(huì)覆蓋已讀取的同名的屬性

  前面兩步好理解,第三步我們可以舉個(gè)例子來看:

    我們在 userMapper.xml 文件中進(jìn)行模糊查詢

<select id="selectLikeUserName" resultType="com.ys.po.User" parameterType="String">
 select * from user where username like '%${jdbc.username}%'
 <!-- select * from user where username like #{username} -->
</select>

    這個(gè)時(shí)候你會(huì)發(fā)現(xiàn)無論你后臺(tái)傳給這個(gè)查詢語句什么參數(shù),都是 select * from user where username like '%root%'

mybatis 的別名配置  

  在 userMapper.xml 文件中,我們可以看到resultType 和 parameterType 需要指定,這這個(gè)值往往都是全路徑,不方便開發(fā),那么我們就可以對這些屬性進(jìn)行一些別名設(shè)置

1、mybatis 默認(rèn)支持的別名


  

2、自定義別名  

  一、定義單個(gè)別名

    首先在全局配置文件 mybatis-configuration.xml 文件中添加如下配置:是在<configuration>標(biāo)簽下

<!-- 定義別名 -->
<typeAliases>
 <typeAlias type="com.ys.po.User" alias="user"/>
</typeAliases>

    第二步通過 user 引用

  二、批量定義別名

    在全局配置文件 mybatis-configuration.xml 文件中添加如下配置:是在<configuration>標(biāo)簽下

<!-- 定義別名 -->
<typeAliases>
 <!-- mybatis自動(dòng)掃描包中的po類,自動(dòng)定義別名,別名是類名(首字母大寫或小寫都可以,一般用小寫) -->
 <package name="com.ys.po"/>
</typeAliases>

總結(jié)

以上所述是小編給大家介紹的MyBatis  Properties及別名定義實(shí)例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Java重寫equals及hashcode方法流程解析

    Java重寫equals及hashcode方法流程解析

    這篇文章主要介紹了Java重寫equals及hashcode方法流程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Springboot集成Mybatis-Flex的示例詳解

    Springboot集成Mybatis-Flex的示例詳解

    Mybatis-Flex 是一個(gè)優(yōu)雅的?Mybatis 增強(qiáng)框架,它非常輕量、同時(shí)擁有極高的性能與靈活性,本文主要介紹了Springboot集成Mybatis-Flex的示例詳解,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01
  • springboot+vue+elementsUI實(shí)現(xiàn)分角色注冊登錄界面功能

    springboot+vue+elementsUI實(shí)現(xiàn)分角色注冊登錄界面功能

    這篇文章主要給大家介紹了關(guān)于springboot+vue+elementsUI實(shí)現(xiàn)分角色注冊登錄界面功能的相關(guān)資料,Spring?Boot和Vue.js是兩個(gè)非常流行的開源框架,可以用來構(gòu)建Web應(yīng)用程序,需要的朋友可以參考下
    2023-07-07
  • JavaIO?BufferedReader和BufferedWriter使用及說明

    JavaIO?BufferedReader和BufferedWriter使用及說明

    這篇文章主要介紹了JavaIO?BufferedReader和BufferedWriter使用及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • linux系統(tǒng)下查看jdk版本、路徑及配置環(huán)境變量

    linux系統(tǒng)下查看jdk版本、路徑及配置環(huán)境變量

    在Linux系統(tǒng)中,配置JDK環(huán)境變量是非常重要的,它可以讓你在終端中直接使用Java命令,這篇文章主要給大家介紹了關(guān)于linux系統(tǒng)下查看jdk版本、路徑及配置環(huán)境變量的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • SpringBoot配置actuator的代碼

    SpringBoot配置actuator的代碼

    這篇文章主要介紹了SpringBoot配置actuator,這里大家需要注意可以監(jiān)控SpringBoot?中的?Tomcat?性能數(shù)據(jù),?以日志形式定期輸出監(jiān)控?cái)?shù)據(jù),?只需要配置一個(gè)Bean,需要的朋友可以參考下
    2022-03-03
  • java獲取版本號(hào)及字節(jié)碼編譯版本方法示例

    java獲取版本號(hào)及字節(jié)碼編譯版本方法示例

    這篇文章主要給大家介紹了關(guān)于java獲得版本號(hào)及字節(jié)碼編譯版本的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • Java多線程之線程通信生產(chǎn)者消費(fèi)者模式及等待喚醒機(jī)制代碼詳解

    Java多線程之線程通信生產(chǎn)者消費(fèi)者模式及等待喚醒機(jī)制代碼詳解

    這篇文章主要介紹了Java多線程之線程通信生產(chǎn)者消費(fèi)者模式及等待喚醒機(jī)制代碼詳解,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10
  • java9學(xué)習(xí)系列之安裝與jshell使用

    java9學(xué)習(xí)系列之安裝與jshell使用

    2017年9月21日,千呼萬喚始出來,Java9終于發(fā)布了。作為自己天天接觸的“對象”,還是應(yīng)該多花點(diǎn)心思去了解她。后續(xù)再進(jìn)一步了解詳細(xì)特性。下面這篇文章主要給大家介紹了關(guān)于java9學(xué)習(xí)系列之安裝與jshell使用的相關(guān)資料,需要的朋友可以參考下。
    2017-09-09
  • Set接口深入剖析之HashSet、LinkedHashSet和TreeSet

    Set接口深入剖析之HashSet、LinkedHashSet和TreeSet

    這篇文章主要介紹了Set接口深入剖析之HashSet、LinkedHashSet和TreeSet,LinkedHashSet是HashSet的子類,實(shí)現(xiàn)了Set接口,LinkedHashSet底層是一個(gè)LinkedHashMap,底層維護(hù)了一個(gè)數(shù)組+雙向鏈表,需要的朋友可以參考下
    2023-09-09

最新評論