Mysql 左连接和与比较

Mysql 左连接和与比较,mysql,sql,Mysql,Sql,我有一个股票购买计划,每个购买交易可以存在多个卖出交易。我正在尝试创建一个查询,该查询将提取我仍有股票投资的任何股票。例如,如果我买50股股票,一天卖出20股,另一天卖出10股,我应该还有20股剩余。我做了大部分艰苦的工作,但我发誓我错过了一些小东西。如果sell_事务表中不存在我的当前查询,则不会提取结果。在我的示例中,这是buy_交易中的交易_id 3,它应该返回100股,但什么也不返回。下面的代码可以放入SQLFIDLE中并进行处理 模式 当前查询 当前查询结果 使用合并: select

我有一个股票购买计划,每个购买交易可以存在多个卖出交易。我正在尝试创建一个查询,该查询将提取我仍有股票投资的任何股票。例如,如果我买50股股票,一天卖出20股,另一天卖出10股,我应该还有20股剩余。我做了大部分艰苦的工作,但我发誓我错过了一些小东西。如果sell_事务表中不存在我的当前查询,则不会提取结果。在我的示例中,这是buy_交易中的交易_id 3,它应该返回100股,但什么也不返回。下面的代码可以放入SQLFIDLE中并进行处理

模式

当前查询

当前查询结果


使用
合并

select bt.buy_transactions_id 
     , bt.symbol
     , bt.shares - coalesce(rt.SoldShares, 0) as remaining_stock
from buy_transactions bt
left join
( select related_buy_transaction
       , sum(shares) as SoldShares
  from sell_transactions
  group by related_buy_transaction ) rt on bt.buy_transactions_id = rt.related_buy_transaction
where bt.shares > coalesce(rt.SoldShares, 0);

以及期望/预期的结果?谢谢。另一个问题。这是我第一个这样的系统。你知道处理这类交易的更好方法吗?
select bt.buy_transactions_id, bt.symbol, bt.shares - rt.SoldShares as remaining_stock
from buy_transactions bt
left join
    (select related_buy_transaction, sum(shares) as SoldShares from sell_transactions group by related_buy_transaction) rt
on bt.buy_transactions_id = rt.related_buy_transaction
where bt.shares - rt.SoldShares > 0;
buy_transactions_id     symbol  remaining_stock
2                       A       10
select bt.buy_transactions_id 
     , bt.symbol
     , bt.shares - coalesce(rt.SoldShares, 0) as remaining_stock
from buy_transactions bt
left join
( select related_buy_transaction
       , sum(shares) as SoldShares
  from sell_transactions
  group by related_buy_transaction ) rt on bt.buy_transactions_id = rt.related_buy_transaction
where bt.shares > coalesce(rt.SoldShares, 0);