mybatis 詳解(四)------properties以及別名定義

来源:http://www.cnblogs.com/ysocean/archive/2017/08/08/7287972.html
-Advertisement-
Play Games

mybatis 詳解(四)------properties以及別名定義 ...


  上一篇博客我們介紹了mybatis的增刪改查入門實例,我們發現在 mybatis-configuration.xml 的配置文件中,對資料庫的配置都是硬編碼在這個xml文件中,如下圖,那麼我們如何改進這個寫法呢?

  

1、我們將 資料庫的配置語句寫在 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>
<!-- 載入資料庫屬性文件 -->
<properties resource="db.properties">
</properties>
 <environments default="development">
    <environment id="development">
      <transactionManager type="JDBC"/>
      <!--dataSource 元素使用標準的 JDBC 數據源介面來配置 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>

  

  如果資料庫有變化,我們就可以通過修改 db.properties 文件來修改,而不用去修改 mybatis-configuration.xml 文件

註意:我們也可以在<properties></properties>中手動增加屬性

<!-- 載入資料庫屬性文件 -->
<properties resource="db.properties">
	<property name="username" value="aaa"/>
</properties>

  那麼這個時候是讀取的username 是以 db.properties 文件中的 root 為準,還是以自己配置的 aaa 為準呢?

我們先看一段 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.");
    }
    /**
     * 根據 properties 元素中的 resource 屬性讀取類路徑下屬性文件,並覆蓋properties 屬性中指定的同名屬性。
     */
    if (resource != null) {
      defaults.putAll(Resources.getResourceAsProperties(resource));
    } else if (url != null) {
      /**
       * 根據properties元素中的url屬性指定的路徑讀取屬性文件,並覆蓋properties 屬性中指定的同名屬性。
       */
      defaults.putAll(Resources.getUrlAsProperties(url));
    }
    /**
     *  獲取方法參數傳遞的properties
     *  創建XMLConfigBuilder實例時,this.configuration.setVariables(props);
     */
    Properties vars = configuration.getVariables();
    if (vars != null) {
      defaults.putAll(vars);
    }
    parser.setVariables(defaults);
    configuration.setVariables(defaults);
  }
}

通過源碼我們可以分析讀取優先順序:

    1、在 properties 內部自定義的屬性值第一個被讀取

    2、然後讀取 resource 路徑表示文件中的屬性,如果有它會覆蓋已經讀取的屬性;如果 resource 路徑不存在,那麼讀取 url 表示路徑文件中的屬性,如果有它會覆蓋第一步讀取的屬性值

    3、最後讀取 parameterType 傳遞的屬性值,它會覆蓋已讀取的同名的屬性

 

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

    我們在 userMapper.xml 文件中進行模糊查詢

  	<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>

    這個時候你會發現無論你後臺傳給這個查詢語句什麼參數,都是 select * from user where username like '%root%'

    

 

 

mybatis 的別名配置  

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

  

 

1、mybatis 預設支持的別名

  

  

 

2、自定義別名  

  一、定義單個別名

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

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

    第二步通過 user 引用

  

  二、批量定義別名

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

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

    引用的時候類名的首字母大小寫都可以


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 題目:通告發佈管理系 語言和環境 A、實現語言 Java B、環境要求 JDK 7.0、Eclipse、Tomcat 7、SQL Server 2008 功能要求 使用JSP實現“通告發佈管理系統”功能,使用SQL Server 2008 作為資料庫,功能包括查詢所有的通告信息與通告信息的修改兩大功 ...
  • 寫在前面: 最近在項目中,遇到一個問題,在點擊一個超鏈接時,頁面報錯。通過瀏覽器調試就可以知道發送的請求參數是不完整的,因為參數中含有特殊字元。所以就報錯啦~~ 原代碼,不能正確發送含有特殊字元的參數: 其中k_projectname中是含有特殊字元的,比如#,在發送請求的時候就不能被識別,需要對其 ...
  • 閱讀目錄: 事件綁定 Toplevel組件 標準對話框 事件綁定 事件綁定: 說明:對於每個組件來說,可以通過bind()方法將函數或方法綁定到具體的事件上。 事件序列: 說明:用戶需要使用bind()方法將具體的事件序列與自定義的方法綁定,時間序列是以字元串的形式表示的。 語法描述: <modif ...
  • 今天我分享一個技術點,利用Spring初始化+線程接管進行程式啟動後保持會話狀態。 先來一段@test單元測試註解,後臺開發的很熟悉,這是測試局部代碼用的: RunWith和ContextConfiguration的源碼和功能就不細解釋了,不熟悉的可以去翻翻源碼。 1:我來一段@Test單元測試操作 ...
  • 工具:eclipse-nion、jdk8、python3.6、pydev eclipse -》 help -》 eclipse marketplace -》 輸入 python,install pydev 接著配置一下eclipse的解釋器以及編碼方式 新建一個項目:new -》project -》 ...
  • /** * 剪切一個文件夾,且文件夾中包含內容,有問題的地方大家可以指出 */import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.File;import java.io.FileI ...
  • 本節作業: 熟練使用類和模塊,寫一個交互性強、有衝突的程式。 一、作業目的 1、規範程式寫法,要按照模塊來規範書寫; 2、類的使用,文件之間的調用練習; 3、思路的開闊,自己編寫衝突,實現調用; 4、對基礎知識的熟練掌握。 本文寫了一個決鬥系統,兩個男的為了一個女的進行決鬥,獲勝者贏得美女放心,失敗 ...
  • 本文介紹將各種Spring的配置方式,幫助您瞭解配置Spring應用的複雜性。Spring是一個非常受歡迎的Java框架,它用於構建web和企業應用。不像許多其他框架只關註一個領域,Spring框架提供了各種功能,通過項目組合來滿足當代業務需求。Spring框架提供了多種靈活的方式配置Bean。例如... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...