1. 程式人生 > >Mybatis不能正確解析typeAliases問題的處理方法

Mybatis不能正確解析typeAliases問題的處理方法

Mybatis配置檔案中使用typeAliases竟然報錯,明明用的是typeAliases,並沒有拼錯。

原來是typeAliasesenvironments相對順序的問題

更改前配置檔案示意圖:

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