Mybatis不能正確解析typeAliases問題的處理方法
阿新 • • 發佈:2019-01-10
Mybatis配置檔案中使用typeAliases
竟然報錯,明明用的是typeAliases
,並沒有拼錯。
原來是typeAliases
與environments
相對順序的問題
更改前配置檔案示意圖:
<environments default="local">
<environment id="local">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/dbname"/>
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment >
</environments>
<typeAliases>
<package name="com.company.models" />
</typeAliases>
typeAliases
節點在environments
節點後面,這種情況下會報錯:
### Error building SqlSession.
### Cause: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 25 ; columnNumber: 17; 元素型別為 "configuration" 的內容必須匹配 "(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,reflectorFactory?,plugins?,environments?,databaseIdProvider?,mappers?)"。
解決方法:把typeAliases
放在environments
前面就不會了
更改後配置檔案示意圖:
<typeAliases>
<package name="com.company.models" />
</typeAliases>
<environments default="local">
<environment id="local">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/dbname"/>
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment>
</environments>