dongqishou7471 2014-03-30 17:19
浏览 28

当一个表包含许多行时从多个表中获取数据

I have two tables, users, and comments.

Users:
id - name - email

comments:
user_id - comment - rating

I am trying to get all the comments for every user, but then put them into an array of this sort of structure.

array(
    'john' => array(
        'comment' => array(
             'text' => "had a great time thanks",
             'rating' => 5,
        )  
        'comment' => array(
             'text' => "awesome",
             'rating' => 5,
        )            
    )
    'amy' => array(
        'comment' => array(
             'text' => "it was ok",
             'rating' => 3,
        )  
        'comment' => array(
             'text' => "awesome",
             'rating' => 3,
        )            
    )
)

Is this possible with one sql statement? Here is my code so far

//get the comments
$stmt = $con->prepare('SELECT c.comment,
                              c.rating,
                              u.username
                    FROM comments c
                    INNER JOIN users u
                    ON c.customer_id = u.id');

$stmt->execute();
$result = $stmt->get_result();
$comments = array();
while($row = $result->fetch_assoc()){
    $comments[] = array(
        'comment' => $row['comment'],
        'rating' => $row['rating'],
        'username' => $row['username']
    );
}

I cant think of the best way to get this structure

  • 写回答

1条回答 默认 最新

  • dongxian7194 2014-03-30 17:51
    关注

    Each key of an array must be unique so you cannot have multiple comment keys at the same level in your array.

    This may be what you need:

    $comment[$row['username']][] = array(
    'comment' => $row['comment'],
    'rating' => $row['rating'],
    );
    
    评论

报告相同问题?

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c