MyBatis XPathParser解析器使用范例詳解
MyBatis是優(yōu)秀的開(kāi)源數(shù)據(jù)庫(kù)框架,本菜鳥(niǎo)抱著學(xué)習(xí)的態(tài)度,通過(guò)《MyBatis技術(shù)內(nèi)幕》一書(shū)來(lái)進(jìn)行MyBatis 的學(xué)習(xí)。
MyBatis 的基礎(chǔ)支撐層使用XPathParser來(lái)實(shí)現(xiàn)XML的解析,紙上得來(lái)終覺(jué)淺,本菜鳥(niǎo)決定親自簡(jiǎn)單實(shí)踐下XPathParser的使用,并在此做下備忘;
首先,XPathParser封裝了XML的document對(duì)象,其構(gòu)造方法較多,個(gè)人選了以下幾個(gè)方法:
第一個(gè)是將XML內(nèi)容作為一個(gè)字符串輸入
public XPathParser(String xml) { commonConstructor(false, null, null); this.document = createDocument(new InputSource(new StringReader(xml))); }
接下來(lái)是添加一個(gè)是否進(jìn)行校驗(yàn)的標(biāo)志位
public XPathParser(String xml, boolean validation) { commonConstructor(validation, null, null); this.document = createDocument(new InputSource(new StringReader(xml))); }
再接下來(lái),是添加一個(gè)Properties 來(lái)作為配置值方便解析(后面寫測(cè)試方法,采用此構(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)上抄來(lái)的,如下所示:
<?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)境:可以配置多個(gè)環(huán)境,default:配置某一個(gè)環(huán)境的唯一標(biāo)識(shí),表示默認(rèn)使用哪個(gè)環(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> <!-- 配置映射文件:用來(lái)配置sql語(yǔ)句和結(jié)果集類型等 --> <mappers> <mapper resource="UserMapper.xml"/> </mappers> </configuration>
我們構(gòu)造一個(gè)Properties對(duì)象,作為構(gòu)造方法的入?yún)ⅲ?/p>
Properties properties = new Properties(); properties.put("jdbc.driverClass", "jdbc.driverClass"); properties.put("jdbc.url","hahaha");
構(gòu)造方法如下(對(duì)付看吧)
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)境:可以配置多個(gè)環(huán)境,default:配置某一個(gè)環(huán)境的唯一標(biāo)識(shí),表示默認(rèn)使用哪個(gè)環(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" + " <!-- 配置映射文件:用來(lái)配置sql語(yǔ)句和結(jié)果集類型等 -->\n" + " <mappers>\n" + " <mapper resource=\"UserMapper.xml\"/>\n" + " </mappers>\n" + "</configuration>", false, properties);
接下來(lái),我們需要針對(duì)準(zhǔn)備的xml文件,來(lái)設(shè)計(jì)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值
前兩個(gè)輸出在此不做描述,我們遍歷xNodes ,可以得到Body的值為:
jdbc.driverClass
hahaha
${jdbc.username}
${jdbc.password}
我們可以發(fā)現(xiàn),jdbc.driverClass,hahaha,都是我們?cè)谌雲(yún)⒌腜roperties中配置的值,因此可以通過(guò)${},來(lái)取出value,而對(duì)于Properties對(duì)象中不存在的值,XPathParser只能取對(duì)應(yīng)的字符串作為value(${jdbc.password}等)。
希望通過(guò)學(xué)習(xí)優(yōu)秀開(kāi)源框架的工具,可以在以后自身工作的開(kāi)發(fā)中學(xué)以致用,更好滴解決實(shí)際問(wèn)題,以后本菜會(huì)多多實(shí)踐優(yōu)秀框架為我們創(chuàng)造的工具,豐富自己的武器庫(kù)。
到此這篇關(guān)于MyBatis XPathParser解析器使用范例詳解的文章就介紹到這了,更多相關(guān)MyBatis XPathParser內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java使用字節(jié)流實(shí)現(xiàn)圖片音頻的復(fù)制
今天帶大家學(xué)習(xí)Java的相關(guān)知識(shí),文章圍繞著Java如何使用字節(jié)流實(shí)現(xiàn)圖片音頻的復(fù)制展開(kāi),文中有非常詳細(xì)的介紹,需要的朋友可以參考下2021-06-06java中synchronized鎖的升級(jí)過(guò)程
這篇文章主要介紹了java中synchronized鎖的升級(jí)過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09java WebSocket客戶端斷線重連的實(shí)現(xiàn)方法
在工作中是否會(huì)遇到實(shí)用websocket客戶端連接服務(wù)端的時(shí)候,網(wǎng)絡(luò)波動(dòng),服務(wù)端斷連的情況,本文可以直接使用的斷線重連,感興趣的可以了解一下2021-10-10詳解Java中Checked Exception與Runtime Exception 的區(qū)別
這篇文章主要介紹了詳解Java中Checked Exception與Runtime Exception 的區(qū)別的相關(guān)資料,這里提供實(shí)例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08詳解Spring Security中的HttpBasic登錄驗(yàn)證模式
HttpBasic登錄驗(yàn)證模式是Spring Security實(shí)現(xiàn)登錄驗(yàn)證最簡(jiǎn)單的一種方式,也可以說(shuō)是最簡(jiǎn)陋的一種方式,這篇文章主要介紹了Spring Security的HttpBasic登錄驗(yàn)證模式,需要的朋友可以參考下2019-11-11詳解java平臺(tái)解析協(xié)議相關(guān)備忘
這篇文章主要介紹了詳解java平臺(tái)解析協(xié)議相關(guān)備忘,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01SpringCloud?Gateway讀取Request?Body方式
這篇文章主要介紹了SpringCloud?Gateway讀取Request?Body方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03