当前位置: 代码迷 >> SQL >> 两个表没有相同记录的查询如何写(一个表有,另一个表没)
  详细解决方案

两个表没有相同记录的查询如何写(一个表有,另一个表没)

热度:154   发布时间:2016-05-05 15:26:39.0
两个表没有相同记录的查询怎么写(一个表有,另一个表没)
我的问题:  
  表debt里有stunum(主),stuname,owetui,owebo
  表charge里有stunum,stuname,classname,tal等字段 
 我要查询的结果是:
  stunum,stuname,classname,tal,total,owe
  其中查询结果里的
  tal=表charge里相同stunum的tal和。(例如stunum=08006那么若表debt里有这条记录而表chrge里没有,则tal=0.
  若是两个表里都有的话。则tal=表charge里相同stunum的tal和。
  total=表里的owetui+owebo (这个我懂怎么写)
  owe=查询出来的tal-total 

  我主要是不懂怎么写在表charge里没有这条记录时的SQL,要是有相同记录的我还会写,帮我写下,谢谢

------解决方案--------------------
用LEFT JOIN
然后再IFNULL判断一下。
------解决方案--------------------


(不要高估你的汉语表达能力或者我的汉语理解能力)
建议你列出你的表结构,并提供测试数据以及基于这些测试数据的所对应正确结果。
参考一下这个贴子的提问方式http://topic.csdn.net/u/20091130/20/8343ee6a-417c-4c2d-9415-fa46604a00cf.html
 
1. 你的 create table xxx .. 语句
2. 你的 insert into xxx ... 语句
3. 结果是什么样,(并给以简单的算法描述)
 
这样想帮你的人可以直接搭建和你相同的环境,并在给出方案前进行测试,避免文字描述理解上的误差。


------解决方案--------------------
charge left join debt, 然后再select sum
  相关解决方案