dongyue0225 2012-08-09 06:21
浏览 13
已采纳

SQL - 加入两个表

I am trying to grasp the topic of joining tables in SQL. I know there are multiple joins but not sure which to implement here:

Here is my SQL line in php:

$sql=mysql_query("
SELECT * FROM comments 
WHERE item_id = '{$item_id}' 
   AND review > '' 
ORDER BY good DESC, rate_id ASC");

This is what I want to join with: Another table called "users". *"users" and "comments" both have a column called "user_id" to join.* I want to associate those two to find the full "username" in the users table.

I know SELECT is not best practice; but for the sake of this demo, can you include that here? I also know MySQL injection possibilities to watch for. **

  • 写回答

2条回答 默认 最新

  • doujunchi1238 2012-08-09 06:23
    关注

    I'd recommend you to use the ANSI SQL-92 format rather than ANSI SQL-89. Try this one:

    SELECT a.* , b.*
    FROM comments a
            INNER JOIN users b
                ON a.user_id = b.user_id
    WHERE item_id = '{$item_id}'  AND 
          review > '' 
    ORDER BY good DESC, rate_id ASC
    

    Good Definition of JOINs
    Read something here: INNER JOIN (ANSI SQL-89 vs ANSI SQL-92)

    Additional Information:

    Since you are using PHP for this, I'll also recommend to use PHP PDO Technology

    an example for that is:

    <?php
    
    
    $stmt = $dbh->prepare("SELECT a.* , b.*
        FROM comments a
                INNER JOIN users b
                    ON a.user_id = b.user_id
        WHERE item_id = ?  AND 
              review > ? 
        ORDER BY good DESC, rate_id ASC");
    
    $stmt->bindParam(1, $item_id);
    $stmt->bindParam(2, '');
    $stmt->execute();
    
    ?>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?