我正在做一个需要我从草图构建论坛系统的项目
但是我面临一个关于 SQL 的问题
我正在使用 Derby 数据库。
表结构如下。
表论坛主题( TID INTEGER NOT NULL 始终作为 IDENTITY 生成(从 1 开始,按 1 递增)主键, TTitle varchar(50) 非空, UID 整数非空, CID Char(7) 非空, 粘性布尔值不为空, 状态字符(1) ) ==========一个话题的内容和回复======== 表论坛主题内容( RID INTEGER NOT NULL 始终作为标识生成(从 1 开始,按 1 递增)主键, Rcontent varchar(10000) 不为空, RTime 时间戳不为空, REditTime时间戳, UID 整数非空, TID 整数非空, 状态字符(1) ) 表用户 ( UID INTEGER NOT NULL 始终作为 IDENTITY 生成(从 1 开始,按 1 递增)主键, UName varchar(50) NOT NULL, UNick varchar(50) 非空, ULoginName varchar(16) NOT NULL, Upwd varchar(16) 非空, UPic varchar(200), UType Char(1) NOT NULL ) =========外键========== ALTER TABLE 论坛主题内容 添加约束 Forum_reply_fk_thread 外键 (TID) REFERENCES ForumThread(TID); 更改表论坛主题 添加约束 forum_thread_fk_User Foreign Key (UID) References Users(UID);
在论坛中显示单线程的UI设计将显示以下信息。每页显示 10 个线程
- 主题标题 (ForumThread.TTitle)
- 主题作者(Users.UNick)
- 该线程中的回复数
- 最新回复时间(ForumThreadContent RTime)
- 最新回复者的昵称 (Users.UNick)
我的 SQL 语句。
SELECT ftc.tid ,ft.TTitle, ss.uNick as "Author", s.Unick as "Last replied by" , MAX(ftc.RTIME) as "Last Reply Time", COUNT(*) AS "Posts Count"
FROm ForumThreadContent ftc, Users s, ForumThread ft, Users ss
WHERE ftc.UID = s.UID
AND ftc.TID = ft.TID
AND ft.UID = ss.UID
Group by ftc.tid , ft.ttitle , s.uNick , ss.uNick
Having MAX(ftc.RTIME) IN (SELECT MAX(ftcc1.RTime)
FROM ForumThreadContent ftcc1
WHERE ftc.TID = ftcc1.tid)
该语句可以正确执行。假设TID "1" 中有3 个回复,当我运行它时, COUNT(*) 只计算 tid: 1 的 "2"。要清楚:
- ForumThreadContent 中的 3 行具有 TID 的外键“1”
- 3 行的第一行有一个 UID 的外键“1”
- 其余的有一个UID的外键“2”
在这种情况下是否可以正确执行 count() 函数?我的 SQL 永远无法得到高于 2 的数字。