gpt4 book ai didi

sql - 超过 3 个表的棘手 SQL 语句

转载 作者:行者123 更新时间:2023-11-29 01:34:16 25 4
gpt4 key购买 nike

我有 3 个不同的交易表,它们看起来非常相似,但略有不同。这是因为有 3 种不同的交易类型;根据交易类型,列会发生变化,因此要将它们放入 3NF,我需要将它们放在单独的表中(对吗?)。

举个例子:
t1:日期,用户,金额

t2:日期、用户、用户、金额

t3:日期,用户,内容,金额

现在我需要一个查询,该查询将为同一用户获取每个表中的所有事务,例如

select * from t1,t2,t3 where user='me';(这当然行不通)。

我正在研究 JOIN 语句,但还没有找到正确的方法来做到这一点。谢谢。

编辑:实际上我需要每个表中的所有列,而不仅仅是相同的列。


编辑 #2:是的,拥有 transaction_type 不会破坏 3NF,当然 - 所以也许我的设计是完全错误的。这是真正发生的事情(这是一种替代货币系统):
- 交易是在用户之间进行的,就像相互信用一样。所以单位会在用户之间交换。
- Inventarizations 是带入系统的物理东西;用户为此获得单位。
- 消耗品是消耗的物质;用户必须为此支付单位费用。

|--------------------------------------------------------------------------||  type     |  transactions       |  inventarizations  |  consumations     ||--------------------------------------------------------------------------||  columns  |  date               |  date              |  date             ||           |  creditor(FK user)  |  creditor(FK user) |                   ||           |  debitor(FK user)   |                    |  debitor(FK user) ||           |  service(FK service)|                    |                   ||           |                     |  asset(FK asset)   |  asset(FK asset)  ||           |  amount             |  amount            |  amount           ||           |                     |                    |  price            ||--------------------------------------------------------------------------|

(请注意,“金额”的单位不同;这些是条目,计算是根据这些金额进行的。超出了解释原因的范围,但这些是字段)。
所以问题更改为“这可以/应该在一个表中还是在多个表中(就像我现在拥有的那样)?”我需要前面描述的 SQL 语句来显示运行余额。


(这现在应该完全成为一个新问题还是可以编辑?)。

编辑 #3:由于编辑 #2 实际上将其转换为一个新问题,我还决定发布 a new question . (我希望这没问题?)。

最佳答案

您可以在选择语句中为没有数据的列提供默认值作为常量;

所以

SELECT Date, User, Amount, 'NotApplicable' as Who, 'NotApplicable' as What from t1 where user = 'me'
UNION
SELECT Date, User, Amount, Who, 'NotApplicable' from t2 where user = 'me'
UNION
SELECT Date, User, Amount, 'NotApplicable', What from t3 where user = 'me'

假设 Who 和 What 是字符串类型的列。您也可以使用 Null,但需要某种占位符。

我认为将您的附加信息放在一个单独的表中并将所有事务保存在一个表中对您来说会更好,除非我遗漏了一些其他细节。

关于sql - 超过 3 个表的棘手 SQL 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1413058/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com