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)文章
Java使用字節(jié)流實現(xiàn)圖片音頻的復(fù)制
今天帶大家學(xué)習(xí)Java的相關(guān)知識,文章圍繞著Java如何使用字節(jié)流實現(xiàn)圖片音頻的復(fù)制展開,文中有非常詳細(xì)的介紹,需要的朋友可以參考下2021-06-06java WebSocket客戶端斷線重連的實現(xiàn)方法
在工作中是否會遇到實用websocket客戶端連接服務(wù)端的時候,網(wǎng)絡(luò)波動,服務(wù)端斷連的情況,本文可以直接使用的斷線重連,感興趣的可以了解一下2021-10-10詳解Java中Checked Exception與Runtime Exception 的區(qū)別
這篇文章主要介紹了詳解Java中Checked Exception與Runtime Exception 的區(qū)別的相關(guān)資料,這里提供實例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08詳解Spring Security中的HttpBasic登錄驗證模式
HttpBasic登錄驗證模式是Spring Security實現(xiàn)登錄驗證最簡單的一種方式,也可以說是最簡陋的一種方式,這篇文章主要介紹了Spring Security的HttpBasic登錄驗證模式,需要的朋友可以參考下2019-11-11SpringCloud?Gateway讀取Request?Body方式
這篇文章主要介紹了SpringCloud?Gateway讀取Request?Body方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03