dongtan2603 2012-01-04 22:03
浏览 84
已采纳

SELECT语句在另一个SELECT语句中

I have two tables called messages and users. In the messages table, there's a field which is a foreign key to the users table that is basically the users ID. I am trying to retrieve results from the messages table using a SELECT query, but I want the users username rather than their user ID. This SQL is wrong but I think it gets across the idea of what I'm trying to do:

SELECT (SELECT username FROM `users` WHERE u_id=?), message, sent FROM `messages` WHERE r_id=? AND sent > ?

Basically, I want to use the users ID stored in the messages table to get the users username to be returned AND get results from the messages table in one query.

I think JOINs are the tool for this, but I have very little bar no SQL experience.

Thanks.

  • 写回答

5条回答 默认 最新

  • dsc6517 2012-01-04 22:05
    关注

    You want to JOIN the two tables together, using the common u_id column.

    SELECT u.username, m.message, m.sent
        FROM messages m
            INNER JOIN users u
                ON m.u_id = u.u_id 
        WHERE m.r_id = ?
            AND m.sent > ?
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 关于大棚监测的pcb板设计
  • ¥20 sim800c模块 at指令及平台
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计