首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用3个表时,操作数应包含1列

使用3个表时,操作数应包含1列
EN

Stack Overflow用户
提问于 2013-04-26 17:57:42
回答 1查看 54关注 0票数 0

我有3张表:COMMUNITIESMEMBERSCHECKINS

根据访问者的社区选择,我想要属于该社区的成员的最后一次签到列表。

我收到以下代码的Operand should contain 1 column(s)错误。

我将感谢你的帮助!

代码语言:javascript
运行
复制
    cFilter = Request.QueryString("Filter")


SQL = "SELECT C.CheckinID, C.CheckInPlatform, C.MemberID, C.VENUENAME, C.VENUECITY, C.VENUECOUNTRY, C.VENUECREATEDAT, C.CheckInDateEntered"
    SQL = SQL & " FROM CHECKINS C"
    SQL = SQL & " WHERE C.CheckinID"
    SQL = SQL & " IN ( SELECT MAX(CheckinID)"
    SQL = SQL & " FROM CHECKINS"
    SQL = SQL & " GROUP BY MemberID"
    SQL = SQL & " )"
    SQL = SQL & " AND C.MemberID"
    SQL = SQL & " IN ( SELECT M.MemberID, M.CommunityID"
    SQL = SQL & " FROM MEMBERS M"
    SQL = SQL & " WHERE M.CommunityID = "& cFilter &""
    SQL = SQL & " )"
    SQL = SQL & " ORDER BY C.CheckInDateEntered DESC"
    Set objCheckins = objConn.Execute(SQL)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-26 18:02:35

以下数据段:

代码语言:javascript
运行
复制
C.MemberID IN ( SELECT M.MemberID, M.CommunityID
    FROM MEMBERS M
    WHERE M.CommunityID = <your var here>
    )

应该细分为:

代码语言:javascript
运行
复制
(
(C.MemberID IN ( SELECT M.MemberID
    FROM MEMBERS M
    WHERE M.CommunityID = <your var here>
    )
)
OR
(C.MemberID IN ( SELECT M.CommunityID
    FROM MEMBERS M
    WHERE M.CommunityID = <your var here>
    )
)
)

虽然我认为OR条款的后面部分可以跳过。

编辑

由于您选择的是带有条件M.CommunityID = <your var here>M.CommunityID;所以像:C.MemberID = <your var here>这样的简单语句就足够了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16233663

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档