sql语句连接查询的问题

我现在有两张表,一张target目标表,一张费用表,目标表一个用户每个月就一条记录,比如设定的各个要完成的目标,费用表可能一个月有好几条记录,记录已完成的数据,表之间的关联用用户的ID,现在遇到问题,想在一个列表中展示目标数据和已完成数据,目标表有目标月份日期字段,费用表有生效日期字段
[table]
目标月份 目标标保 已完成标保 目标佣金 已完成佣金 目标件数 已完成件数
2012-11 1000 500 200000 2000 500 50
[/table]
我现在sql语句如下
[code="java"] select SALES_CODE,target.TARGET_MONTH as targetMonth,target.STD_PREM as stdPrem,target.BROKERAGE as brokerage,target.CASES as cases,
d.toStdPrem as totStdPrem,d.toBrokerage as totBrokerage,d.toCases as totCases
from AB_TARGET target inner join
(select sum(com.STANDARD_PAYMENT) as toStdPrem,
sum(com.FINAL_PAY_AMOUNT) as toBrokerage,
count(com.id) as toCases,com.SALE_ID,SOURCE
from COMMISSION_INFO com


<![CDATA[ com.EFFECTIVE_DATE >= #{targetMonthBegin}]]>


<![CDATA[ and com.EFFECTIVE_DATE <= #{targetMonthEnd}]]>


group by com.sale_id, com.source)d on target.SALES_CODE = d.SALE_ID

AND target.SALES_CODE = #{salesCode} and d.source='1801'



<![CDATA[ target.TARGET_MONTH >= #{targetMonthBegin}]]>


<![CDATA[ and target.TARGET_MONTH <= #{targetMonthEnd}]]>

      <if test="@Ognl@isNotEmpty(salesName)">
            AND target.SALES_CODE =#{salesName} 
        </if>
    <if test="@Ognl@isNotEmpty(sortColumns)">
        ORDER BY ${sortColumns}
    </if>
    </where>[/code]

查询出的数据不正确,比如目标表11月份和12月份有两条数据,而费用表仅11月份有数据,结果按照上面语句查询出来11月份和12月份的费用已完成的情况是一样的,正确的费用表12月份查出来相应已完成的记录应该为空,求解答

3个回答

怀疑这个联表条件(on target.SALES_CODE = d.SALE_ID)的正确性?
有日期条件的时候查询结果才是对的,很有可能是日期条件+target.SALES_CODE = d.SALE_ID这个才能真正定位目标表对应的费用明细;

TARGET_MONTH >targetMonthBegin
TARGET_MONTH 你的费用表种的生效日期字段
是不是11月份的 生效日期 肯定是>=11.1 <==11.30
如果是这样就应该没得问题
或者你打印下执行的sql语句
放到查询分析器 看看

tearhero
tearhero 怀疑这个联表条件(on target.SALES_CODE = d.SALE_ID)的正确性? 有日期条件的时候查询结果才是对的,很有可能是日期条件+target.SALES_CODE = d.SALE_ID这个才能真正定位目标表对应的费用明细;
接近 7 年之前 回复
goodluck_wgw
goodluck_wgw ,目标表有12月份数据,费用表没有12月份的数据,怎样让查询出来的12月份目标表有数据,而费用表已完成的记录为空
接近 7 年之前 回复
goodluck_wgw
goodluck_wgw 我现在没有传日期,查询结果才不对 select * from ( select SALES_CODE,target.TARGET_MONTH as targetMonth,target.STD_PREM as stdPrem,target.BROKERAGE as brokerage,target.CASES as cases, d.toStdPrem as totStdPrem,d.toBrokerage as totBrokerage,d.toCases as totCases from AB_TARGET target inner join ( select sum(com.STANDARD_PAYMENT) as toStdPrem, sum(com.FINAL_PAY_AMOUNT) as toBrokerage, count(com.id) as toCases,com.SALE_ID,SOURCE from COMMISSION_INFO com group by com.sale_id, com.source )d on target.SALES_CODE = d.SALE_ID AND target.SALES_CODE = '100004344' and d.source='1801' ) where rownum <= 10 生成的是这条语句
接近 7 年之前 回复

比如目标表11月份和12月份有两条数据,而费用表仅11月份有数据,结果按照上面语句查询出来11月份和12月份的费用已完成的情况是一样的,正确的费用表12月份查出来相应已完成的记录应该为空,求解答

很明显你的需求是外连 不是 内连

即目标和费用直接是外链关系 如用left join

jinnianshilongnian
jinnianshilongnian 哦,mybatis这个拼的太麻烦 建议你贴个sql 然后 1、测试不连费用时的查询是不是两个(怀疑是这出问题了) 2、如果成功再外链费用表
接近 7 年之前 回复
goodluck_wgw
goodluck_wgw 左右连接都试过,查的数据都不正确
接近 7 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!