ibatis遇到的问题

最近有个统计各个业务完成情况的任务,涉及到7个表,最后的结果需要合并起来显示给客户端,所以使用union连接

最开始的版本是在java代码中用字符串拼接起来的,因为看起来特别不方便,于是想到用存储过程的形式,返回游标,读取结果,存储过程在上一篇文章中,在测试机测试的时候还正常,等到更版的时候从游标获取结果集那一步响应时间特别长,因为时间紧迫,对存储过程不甚了解,所以想到用ibatis把SQL写到xml文件里面方便其他人看

遇到的第一个问题:总共传进去两个参数,在SQL中有24处用到,每个参数各12次,启动之后报错:未明确定义列,在错误提示中看到了传过来的参数名param,这个时候不太明白,有人说可能是参数的数量对不上,传了2个,用了22个,想想也是有道理,然后根据这个提示把两个参数加了标志符各12个,如param12,启动之后又提示:未明确定义列,这次的提示关键词是param9,这个让人摸不着头脑了,意思是前16个参数都过了,第17个过不去了?这个只是猜测,网上未找到资料所以放弃这种方式,把union拆开了,结果集合并后返回,这个错误没有再出现

第二个问题:因为SQL中有中文字符,启动之后又报错:缺失关键字,SQL打印出来看到中文变成乱码了,然后检查头部的encoding="UTF-8",网上资料说需要改成gbk,改了之后还是这个错误提示,然后点击文件,右键properties菜单找到最下面的text file encoding这个地方改为gbk,然后需要回去看一下有没有乱码修复一下,启动之后正常

最后验证了一下上面的问题:

当SQL中有重复使用一个参数时是否有问题?测试结果是没有问题,union拆开之后的SQL也有多处使用同一个参数的

ibatis接收参数类型为map时map有长度限制16吗?还未知,实际情况中超过16是不行的

SQL的编码问题是由谁来控制?还不明确,虽然有很多资料可以查

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值