第一个bug,gateway不能自动注入进Controller!
原因是ibatis插件没有把欲注入的gateway首字母改成小写
可修改C:\Documents and Settings\XX\.grails\2.0.0\projects\XX\plugins\ibatis-1.3.1\ IbatisGrailsPlugin.groovy
把
改为
第二个bug,SQL定义里引用包含其他SQL时会出错,如我们定义了一个userGateway,SQL写在这个文件里user.xml
getUsers SQL引用包含了getUsersMain片段,但mybatis就是不认,报错XML fragments parsed from previous mappers does not contain value for ......
原因是grails 的ibatis1.3.1插件用的是mybatis3.04, 而3.04版有这个bug,所以把mybatis升级到最新的3.06吧。
可以把grails-ibatis-1.3.1.zip从官网下载下来,然后解压修改以下文件。
dependencies.groovy改2行
当然第一个bug你也可以改解压出来的IbatisGrailsPlugin.groovy
改完以后要重装ibatis plugin了
1.首先到你的工程目录下执行grails uninstall-plugin ibatis
2.然后把grails插件的缓存清掉
删除.grails\ivy-cache\org.mybatis
删除.grails\ivy-cache\org.grails.plugins\ibatis
删除.grails\2.0.0\cached-installed-plugins
3.安装新的插件
把你刚才改好的ibatis重新打包为grails-ibatis-1.3.1.zip,比如放在D盘根目录,
到你的工程目录下执行grails install-plugin d:/grails-ibatis-1.3.1.zip
OK了,SQL套SQL终于可以正常执行了。
第三个bug,解析XML时候会尝试连接http://mybatis.org/dtd/mybatis-3-mapper.dtd ,如果机器连不到internet,就会报错。
这个其实原版的mybatis是没有这个问题的,它用了一个EntityResolver来解决这个问题的。到了ibatis plugin就有这个问题了。
解决方法就是修改插件下面的src\groovy\org\codehaus\groovy\grails\plugins\ibatis\ MappingSupport.groovy改123行
改为
原因是ibatis插件没有把欲注入的gateway首字母改成小写
可修改C:\Documents and Settings\XX\.grails\2.0.0\projects\XX\plugins\ibatis-1.3.1\ IbatisGrailsPlugin.groovy
把
"${a.shortName}"(a.clazz) { bean ->
改为
def shortName = a.shortName[0].toLowerCase() + a.shortName[1..-1];
"${shortName}"(a.clazz) { bean ->
第二个bug,SQL定义里引用包含其他SQL时会出错,如我们定义了一个userGateway,SQL写在这个文件里user.xml
<select id="getUsers" parameterType="xx" resultType="xx">
<include refid="getUsersMain" />
</select>
<sql id="getUsersMain">
SELECT * FROM USER
</sql>
getUsers SQL引用包含了getUsersMain片段,但mybatis就是不认,报错XML fragments parsed from previous mappers does not contain value for ......
原因是grails 的ibatis1.3.1插件用的是mybatis3.04, 而3.04版有这个bug,所以把mybatis升级到最新的3.06吧。
可以把grails-ibatis-1.3.1.zip从官网下载下来,然后解压修改以下文件。
dependencies.groovy改2行
compile 'org.mybatis:mybatis:3.0.6'
compile('org.mybatis:mybatis-spring:1.0.2') {
当然第一个bug你也可以改解压出来的IbatisGrailsPlugin.groovy
改完以后要重装ibatis plugin了
1.首先到你的工程目录下执行grails uninstall-plugin ibatis
2.然后把grails插件的缓存清掉
删除.grails\ivy-cache\org.mybatis
删除.grails\ivy-cache\org.grails.plugins\ibatis
删除.grails\2.0.0\cached-installed-plugins
3.安装新的插件
把你刚才改好的ibatis重新打包为grails-ibatis-1.3.1.zip,比如放在D盘根目录,
到你的工程目录下执行grails install-plugin d:/grails-ibatis-1.3.1.zip
OK了,SQL套SQL终于可以正常执行了。
第三个bug,解析XML时候会尝试连接http://mybatis.org/dtd/mybatis-3-mapper.dtd ,如果机器连不到internet,就会报错。
这个其实原版的mybatis是没有这个问题的,它用了一个EntityResolver来解决这个问题的。到了ibatis plugin就有这个问题了。
解决方法就是修改插件下面的src\groovy\org\codehaus\groovy\grails\plugins\ibatis\ MappingSupport.groovy改123行
new XmlSlurper(validating, true).parseText(text)
改为
def xmlSlurper = new XmlSlurper(validating, true)
xmlSlurper.setEntityResolver(new org.apache.ibatis.builder.xml.XMLMapperEntityResolver())
xmlSlurper.parseText(text)