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>

猜你喜欢

转载自blog.csdn.net/chunyuan314/article/details/77478896