goodluck_wgw
2012-12-04 11:07 阅读 221
已采纳

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条回答 默认 最新

  • 已采纳
    tearhero tearhero 2012-12-04 13:10

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

    点赞 评论 复制链接分享
  • renpeng301 renpeng301 2012-12-04 11:14

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

    点赞 评论 复制链接分享
  • jinnianshilongnian jinnianshilongnian 2012-12-04 12:15

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

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

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

    点赞 评论 复制链接分享

相关推荐