我对 SQL 很陌生,这是一个相当复杂的命令:
SELECT users.name,
from_unixtime(activity.time_stamp, "%D %b %Y %l:%i:%S"),
activity.activity,
activity.rfid_tag,
chemicals.description
FROM activity
JOIN chemicals ON chemicals.bar_code = activity.bar_code
JOIN users ON users.badge_number=activity.badge_number
WHERE (activity="login")
OR (activity="logout")
OR (activity LIKE "Admin:%")
OR (activity="tag")
OR (activity="untag")
OR (activity LIKE "check out%")
OR (activity LIKE "pour%")
OR (activity="check out (unscheduled)")
OR (activity="not poured after checking out")
OR (activity LIKE "invalid:%")
ORDER BY time_stamp DESC
当我运行它时,它只返回与WHERE 的最后一个 OR 匹配的行(867 中的 723)。例如,我没有看到 activity="login" 的任何行,但SELECT * FROM activity WHERE activity="login"
确实返回了一些行。
我究竟做错了什么?(如果那应该是“INNER JOIN”)?
更新
在我添加 Join 之前,我应该说这是有效的(使用复杂的 WHERE)(我是一个完全的 SQL 初学者)。