douyao4632 2017-12-11 20:11
浏览 62
已采纳

PHP - 从数组中查询多个表

I'm really struggling trying to get these two queries (below) together with INNER JOIN. I'm passing an array through in _GET. I wanna select from two different mysql tables.

URL array _GET example: www.mysite.com/users_slideshows[]=one&users_slideshows[]=two&users_slideshows[]=three

Here are my two queries that i'm trying to combine:

$mysqli = new mysqli('localhost','root','1234','root');
$records = array();

foreach ($_GET["users_slideshows"] as $djahjkdsh) {
    $result = $mysqli->query("SELECT * FROM playlist_builder WHERE playlist_builder.volume IN ('".$djahjkdsh."') ");
    while($row = $result->fetch_array(MYSQL_ASSOC)) {
            $records[] = array('tags' => array($row));
    }
    $json = json_encode($records, JSON_PRETTY_PRINT);

}

foreach ($_GET["users_slideshows"] as $djahjkdsh) {
    $result = $mysqli->query("SELECT * FROM custom_slideshow WHERE custom_slideshow.volume IN ('".$djahjkdsh."') ");
    while($row = $result->fetch_array(MYSQL_ASSOC)) {
            $records[] = array('tags' => array($row));
    }
    $json = json_encode($records, JSON_PRETTY_PRINT);

}

If I just choose from one table, it works perfect but it's only when I combine both together.

I've tried the following below... not happening

SELECT * FROM playlist_builder INNER JOIN custom_slideshow ON custom_slideshow.volume = playlist_builder.volume IN ('".$djahjkdsh."')

If anyone could help me on what I'm doing wrong, I would extremely appreciate it. Thanks!

  • 写回答

1条回答 默认 最新

  • dongwo7858 2017-12-11 21:44
    关注

    Your SQL syntax is incorrect since you run two expressions in same logical ON clause. Simply separate the ON clauses into multiple expressions. Also, with one value, use equality over IN.

    SELECT * FROM playlist_builder 
    INNER JOIN custom_slideshow ON custom_slideshow.volume = playlist_builder.volume 
    AND playlist_builder.volume = ?)
    

    Alternatively, with a WHERE clause:

    SELECT * FROM playlist_builder 
    INNER JOIN custom_slideshow ON custom_slideshow.volume = playlist_builder.volume 
    WHERE playlist_builder.volume = ?)
    

    PHP (using parameterization and table aliases)

    $sql = 'SELECT * FROM playlist_builder p 
            INNER JOIN custom_slideshow c ON c.volume = p.volume AND p.volume = ?';
    
    foreach ($_GET["users_slideshows"] as $djahjkdsh) {
    
        $stmt = $mysqli->prepare($sql);
        $stmt->bind_param("s", $djahjkdsh);
        $stmt->execute();
    
        $result = $stmt->get_result();
        while($row =  $result->fetch_assoc()) {
             $records[] = array('tags' => array($row));
        }
        $json = json_encode($records, JSON_PRETTY_PRINT);    
    
        $stmt->close();
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘