php – 来自数组的Foreach mysql查询,然后是来自第一个数组的第二个查询

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – 来自数组的Foreach mysql查询,然后是来自第一个数组的第二个查询脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图从另一个查询的结果循环查询

public static function getActivITyFromUsers()
        {
            $database = DatabaseFactory::getFactory()->getConnection();

// FETCH USER_ID FOR THE SECOND QUERY
            $sql = "SELECT user_id,follower_since_timestamp From users_followers where follower_id = :user_id";
            $query = $database->PRepare($sql);
            $query->execute(array(':user_id' => Session::get('user_id')));


                    if ($query->rowcount() <= 0) {
                        echo 'Nothing';
                        return false;
                    }

    $_MysqL_DATA = $query->fetchAll();

            /* Just for my own testing and troubleshoot */
    foreach ($_MysqL_DATA as $row) {
        echo $row->user_id . " - " . date('d/m/Y H:i:s',$row->follower_since_timestamp) ."<br/>";    
    }
            echo var_dump($_MysqL_DATA).'<br><br>';
            /* End for my own testing and troubleshoot*/

            // USING THE USER_ID´s FROM THE First QUERY TO FETCH DATA FOR OUTPUT
                foreach ($_MysqL_DATA as $row) {
            $sql = "SELECT activity,user_id,activity_timestamp FROM user_activity WHERE user_id = :user_id";
            $query = $database->prepare($sql);
            $query->execute(array(':user_id' => $row->user_id));
            $new_data[] = $query->fetchAll();
            }


    // FOREACH TO OUTPUT DATA FROM SECOND QUERY (SHOULD BE ORDERD BY activity_timestamp)
            foreach($new_data as $key => $object){
                echo 'User_id: ' . $object->user_id.'<br>';
                echo 'What: ' . $object->activity .'<br>';
                echo 'When: ' . date('d/m/Y H:i:s',$object->activity_timestamp) .'<br>';
            }

            echo VAR_dump($new_data);
    }

但是这给了我错误:注意:试图获取非对象的属性.. User_id:等等.

$new_data []的var_dump(来自第二个获取数据的查询)给出了这个:(注意底部的两个数组,为什么是?array [2]&amp; array [3])

array(4) { 
[0]=> array(7) { 
[0]=> object(stdClass)#7 (3) { ["activity"]=> string(15) "Wrote" ["user_id"]=> string(1) "2" ["activity_timestamp"]=> string(10) "1433704851" } 
[1]=> object(stdClass)#17 (3) { ["activity"]=> string(15) "Wrote" ["user_id"]=> string(1) "2" ["activity_timestamp"]=> string(10) "1433832032" } 
[2]=> object(stdClass)#18 (3) { ["activity"]=> string(15) "Wrote" ["user_id"]=> string(1) "2" ["activity_timestamp"]=> string(10) "1433832033" } 
[3]=> object(stdClass)#19 (3) { ["activity"]=> string(15) "Wrote" ["user_id"]=> string(1) "2" ["activity_timestamp"]=> string(10) "1433832035" } 
[4]=> object(stdClass)#20 (3) { ["activity"]=> string(7) "Follows" ["user_id"]=> string(1) "2" ["activity_timestamp"]=> string(10) "1433832150" } 
[5]=> object(stdClass)#21 (3) { ["activity"]=> string(7) "Wrote" ["user_id"]=> string(1) "2" ["activity_timestamp"]=> NULL } 
[6]=> object(stdClass)#22 (3) { ["activity"]=> string(8) "Wrote " ["user_id"]=> string(1) "2" ["activity_timestamp"]=> NULL } } 
[1]=> array(1) { 
[0]=> object(stdClass)#16 (3) { ["activity"]=> string(19) "Finally!" ["user_id"]=> string(1) "3" ["activity_timestamp"]=> string(10) "1433794873" } }
[2]=> array(0) { } 
[3]=> array(0) { } }

如何正确预测第二个查询的结果?

解决方法

为什么不使用单个查询..

SELECT 
    users_followers.user_id,users_followers.follower_since_timestamp,a.activity,a.user_id,a.activity_timestamp 
FROM 
    users_followers
LEFT JOIN 
    (SELECT activity,activity_timestamp FROM user_activity) a
ON a.user_id = users_followers.user_id
where 
    users_followers.follower_id = :user_id

脚本宝典总结

以上是脚本宝典为你收集整理的php – 来自数组的Foreach mysql查询,然后是来自第一个数组的第二个查询全部内容,希望文章能够帮你解决php – 来自数组的Foreach mysql查询,然后是来自第一个数组的第二个查询所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。