“未明确定义列” ibatis的sqlMap中报该

今天用户在使用系统功能中发现有个功能不正常,通过查看后台,发现系统报错,提示 未明确定义列,仔细查看是sqlmap中的一个条件出现了重复列的情况,导致Oracle不知道该条件是提供给那列的

<?xml version="1.0" encoding="GB2312"?>
<!DOCTYPE sqlMap PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN" "http://www.ibatis.com/dtd/sql-map-2.dtd">

<sqlMap namespace="T07_case_Assist">
<statement ....>
	SELECT a.application_num,
		   a.assitno,
		   a.req_organkey,
		   a.req_time,
		   a.reasons,
		   a.deal_organkey,
		   a.handlereport,
		   a.deal_time,
		   a.status,
		   a.deal_user,
		   b.username        as req_username,
		   c.username        as deal_username,
		   t.party_id,
		   t.party_name
	  FROM T07_CASE_ASSIST a
	  left join t00_user c
		on a.deal_user = c.username
	  inner join t00_user b
		on a.req_user = b.username
	  left join T07_CASE_APPLICATION t
		on a.application_num = t.application_num
	 where 1 > 0
	<isNotEmpty prepend="AND" property="application_num">
    APPLICATION_NUM=#application_num#
    </isNotEmpty>
</statement>
</sqlmap>

其中红色行就为报错行,原因是T07_CASE_ASSIST和T07_CASE_APPLICATION中都存在名为APPLICATION_NUM的列,这时候如果仅仅写“APPLICATION_NUM=...”会让数据库困惑,需要带其表的别,也就修改为: a.APPLICATION_NUM=#application_num#可修正该错误


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值