我正在尝试从 GnuCash SQLite 数据库中提取数据。相关表格包括accounts
、transactions
和splits
。简单地说,accounts
包含transactions
哪些包含splits
,并且每个拆分都指向一个帐户。
根据每笔交易是否包含特定类型的交易费用,交易需要进行不同的处理——在这种情况下,交易是否包含与 account 相关的拆分8190-000
。
我设置了两个查询,一个处理有交易费的交易,一个处理没有交易费的交易。查询有效,但它们笨拙且冗长,我相信有更好的方法来做到这一点。我确实看到not exists
了这个答案,但无法弄清楚如何让它在这种情况下工作。
我当前的查询如下所示:
-- Find all transactions containing a split with account code 8190-000
select tx_guid from transactions
inner join
(select tx_guid from
(splits inner join accounts on splits.account_guid = accounts.guid)
where accounts.code = "8190-000") fee_transactions
on fee_transactions.tx_guid = transactions.guid;
-- Find all transactions not containing a split with account code 8190-000
select guid from transactions
except
select tx_guid from transactions
inner join
(select tx_guid from
(splits inner join accounts on splits.account_guid = accounts.guid)
where accounts.code = "8190-000") fee_transactions
on fee_transactions.tx_guid = transactions.guid;
鉴于我需要在其他查询中使用这些结果,那么获取这些交易列表的更简单、更简洁的方法是什么?