MyBatis XPathParser解析器使用范例詳解
MyBatis是優(yōu)秀的開源數(shù)據(jù)庫框架,本菜鳥抱著學(xué)習(xí)的態(tài)度,通過《MyBatis技術(shù)內(nèi)幕》一書來進(jìn)行MyBatis 的學(xué)習(xí)。
MyBatis 的基礎(chǔ)支撐層使用XPathParser來實現(xiàn)XML的解析,紙上得來終覺淺,本菜鳥決定親自簡單實踐下XPathParser的使用,并在此做下備忘;
首先,XPathParser封裝了XML的document對象,其構(gòu)造方法較多,個人選了以下幾個方法:
第一個是將XML內(nèi)容作為一個字符串輸入
public XPathParser(String xml) {
commonConstructor(false, null, null);
this.document = createDocument(new InputSource(new StringReader(xml)));
}接下來是添加一個是否進(jìn)行校驗的標(biāo)志位
public XPathParser(String xml, boolean validation) {
commonConstructor(validation, null, null);
this.document = createDocument(new InputSource(new StringReader(xml)));
}再接下來,是添加一個Properties 來作為配置值方便解析(后面寫測試方法,采用此構(gòu)造方法)
public XPathParser(String xml, boolean validation, Properties variables) {
commonConstructor(validation, variables, null);
this.document = createDocument(new InputSource(new StringReader(xml)));
}我們先準(zhǔn)備一份XML文件,是從網(wǎng)上抄來的,如下所示:
<?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="jdbc.properties"></properties>
<!-- 設(shè)置駝峰匹配 -->
<settings>
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
<!-- 設(shè)置包掃描(別名) -->
<typeAliases>
<package name="cn.itcast.pojo"/>
</typeAliases>
<!-- 配置環(huán)境:可以配置多個環(huán)境,default:配置某一個環(huán)境的唯一標(biāo)識,表示默認(rèn)使用哪個環(huán)境 -->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<!-- 配置連接信息 -->
<property name="driver" value="${jdbc.driverClass}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!-- 配置映射文件:用來配置sql語句和結(jié)果集類型等 -->
<mappers>
<mapper resource="UserMapper.xml"/>
</mappers>
</configuration>我們構(gòu)造一個Properties對象,作為構(gòu)造方法的入?yún)ⅲ?/p>
Properties properties = new Properties();
properties.put("jdbc.driverClass", "jdbc.driverClass");
properties.put("jdbc.url","hahaha");構(gòu)造方法如下(對付看吧)
XPathParser xPathParser = new XPathParser("<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" +
"<!DOCTYPE configuration PUBLIC \"-//mybatis.org//DTD Config 3.0//EN\"\n" +
" \"http://mybatis.org/dtd/mybatis-3-config.dtd\">\n" +
"<configuration>\n" +
" <!-- 引入外部資源文件 -->\n" +
" <properties resource=\"jdbc.properties\"></properties>\n" +
" <!-- 設(shè)置駝峰匹配 -->\n" +
" <settings>\n" +
" <setting name=\"mapUnderscoreToCamelCase\" value=\"true\"/>\n" +
" </settings>\n" +
" <!-- 設(shè)置包掃描(別名) -->\n" +
" <typeAliases>\n" +
" <package name=\"cn.itcast.pojo\"/>\n" +
" </typeAliases>\n" +
" <!-- 配置環(huán)境:可以配置多個環(huán)境,default:配置某一個環(huán)境的唯一標(biāo)識,表示默認(rèn)使用哪個環(huán)境 -->\n" +
" <environments default=\"development\">\n" +
" <environment id=\"development\">\n" +
" <transactionManager type=\"JDBC\"/>\n" +
" <dataSource type=\"POOLED\">\n" +
" <!-- 配置連接信息 -->\n" +
" <property name=\"driver\" value=\"${jdbc.driverClass}\"/>\n" +
" <property name=\"url\" value=\"${jdbc.url}\"/>\n" +
" <property name=\"username\" value=\"${jdbc.username}\"/>\n" +
" <property name=\"password\" value=\"${jdbc.password}\"/>\n" +
" </dataSource>\n" +
" </environment>\n" +
" </environments>\n" +
" <!-- 配置映射文件:用來配置sql語句和結(jié)果集類型等 -->\n" +
" <mappers>\n" +
" <mapper resource=\"UserMapper.xml\"/>\n" +
" </mappers>\n" +
"</configuration>", false, properties);接下來,我們需要針對準(zhǔn)備的xml文件,來設(shè)計XPath表達(dá)式,XPath表達(dá)式可以在此處學(xué)習(xí)
String string1 = xPathParser.evalString("http://typeAliases/package/@name"); //typeAliases下package標(biāo)簽的name值
String string2 = xPathParser.evalString("http://environments/environment/dataSource/@type"); //environments下environment下dataSource標(biāo)簽的type值
List<XNode> xNodes = xPathParser.evalNodes("http://dataSource/property/@value"); //dataSource下property下的所有value值前兩個輸出在此不做描述,我們遍歷xNodes ,可以得到Body的值為:
jdbc.driverClass
hahaha
${jdbc.username}
${jdbc.password}
我們可以發(fā)現(xiàn),jdbc.driverClass,hahaha,都是我們在入?yún)⒌腜roperties中配置的值,因此可以通過${},來取出value,而對于Properties對象中不存在的值,XPathParser只能取對應(yīng)的字符串作為value(${jdbc.password}等)。
希望通過學(xué)習(xí)優(yōu)秀開源框架的工具,可以在以后自身工作的開發(fā)中學(xué)以致用,更好滴解決實際問題,以后本菜會多多實踐優(yōu)秀框架為我們創(chuàng)造的工具,豐富自己的武器庫。
到此這篇關(guān)于MyBatis XPathParser解析器使用范例詳解的文章就介紹到這了,更多相關(guān)MyBatis XPathParser內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于IntelliJ IDEA 打包代碼報錯的問題
這篇文章主要介紹了關(guān)于IntelliJ IDEA 打包代碼報錯的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
Java設(shè)計模式之解釋器模式_動力節(jié)點Java學(xué)院整理
解釋器模式是一個比較少用的模式,本人之前也沒有用過這個模式。下面我們就來一起看一下解釋器模式2017-08-08
Java elasticSearch-api的具體操作步驟講解
這篇文章主要介紹了elasticSearch-api的具體操作步驟講解,本文通過詳細(xì)的步驟介紹和圖文代碼展示講解了該項技術(shù),需要的朋友可以參考下2021-06-06
MyBatis 多個條件使用Map傳遞參數(shù)進(jìn)行批量刪除方式
這篇文章主要介紹了MyBatis 多個條件使用Map傳遞參數(shù)進(jìn)行批量刪除方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
Invalid bound statement(not found):錯誤的解決方案
本文介紹了在開發(fā)Java SpringBoot應(yīng)用程序時出現(xiàn)的"Invalidboundstatement(notfound)"錯誤的原因及解決方法,該錯誤通常與MyBatis或其他持久化框架相關(guān),可能是由于配置錯誤、拼寫錯誤或其他問題引起的,解決方法包括檢查SQL映射文件2025-01-01
Java中final,finally,finalize?有什么區(qū)別
這篇文章主要給大家分享的是?Java中final,finally,finalize?到底有什么區(qū)別,文章圍繞final,finally,finalize的相關(guān)資料展開詳細(xì)內(nèi)容,具有一定的參考的價值,需要的朋友可以參考一下2021-11-11

