php 表警告:为 foreach 提供的参数无效

发布于 2024-11-29 21:35:38 字数 2670 浏览 0 评论 0原文

我想根据下面的查询输出一个 5 列表,phpmyadmin 上的输出是正确的,但我收到错误:

为 php 页面上的 foreach() 提供的参数无效。任何帮助将不胜感激。感谢

码:

<?php

$database =& JFactory::getDBO(); 

//Declare Variables
$user = JFactory::getUser();
$id = $user->get('id');
$name = $user->get('name');

// Display quizzes
echo "</br>";
echo "Quizzes History for : " ;
echo "<b>";
echo $name;
echo "</b>";


echo "</br>";
echo "</br>";

$database->setQuery(" SELECT distinct qui.title AS name,   

( SELECT GROUP_CONCAT(profiles.title)

  FROM jos_jquarks_users_profiles AS users_profiles    
  LEFT JOIN jos_jquarks_profiles AS profiles ON users_profiles.profile_id = profiles.id     
  WHERE users_profiles.user_id = sessionWho.user_id ) AS profile,    
   ( SELECT sum(score) 
 FROM jos_jquarks_quizzes_answersessions     

  WHERE quizsession_id = quizSession.id              AND status <> -1 ) AS score, 

( SELECT count(distinct question_id)              FROM jos_jquarks_quizzes_answersessions            
  WHERE quizsession_id = quizSession.id ) AS maxScore,            
DATE_FORMAT(quizSession.finished_on,'%M %d, %Y') AS FinishedOn
 FROM jos_jquarks_quizsession AS quizSession  

LEFT JOIN jos_jquarks_users_quizzes AS users_quizzes ON users_quizzes.id = quizSession.affected_id    
LEFT JOIN jos_jquarks_quizzes AS qui ON users_quizzes.quiz_id = qui.id     
LEFT JOIN jos_jquarks_quizzes_answersessions AS quizSessAns ON quizSessAns.quizsession_id = quizSession.id 
LEFT JOIN jos_jquarks_sessionwho AS sessionWho ON sessionWho.session_id = quizSession.id        
LEFT JOIN jos_jquarks_users_profiles AS users_profiles ON users_profiles.user_id = sessionWho.user_id 
LEFT JOIN jos_jquarks_profiles AS profiles ON profiles.id = users_profiles.profile_id   
WHERE sessionWho.user_id =  ' .$id  " ) ;


if (!$database->query()) { //write data and if error occurs alert
    echo "<script> alert('".$database->getErrorMsg()."'); </script>";
}

//var_dump($database);
$tableStyle = "padding: 5px;border:1px"; 
$tdStyle = "padding:5px "; 
$thStyle = "padding:7px ";

echo '<table style="' . $tableStyle . '" cellpadding="7" cellspacing="7">'; 
echo "<tr> <th style=align:center>Quiz Title </th><th style=align:center> Score </th><th>Maximum Score </th><th> Unanswered </th> <th>Finished On </th></tr>"; 

$row = $database->loadRowList();
foreach($row as $valuearray)
{
echo '<tr style=" align="center">';
foreach($valuearray as $field)
{

echo "<td>$field</td>";
}
echo "</tr>";
}
echo "</table>";

?>

I want to output a 5 column table based on the query below , the output on phpmyadmin is correct but I am getting error :

Invalid argument supplied for foreach() on the php page. Any help would be highly appreciated. Thanks

code :

<?php

$database =& JFactory::getDBO(); 

//Declare Variables
$user = JFactory::getUser();
$id = $user->get('id');
$name = $user->get('name');

// Display quizzes
echo "</br>";
echo "Quizzes History for : " ;
echo "<b>";
echo $name;
echo "</b>";


echo "</br>";
echo "</br>";

$database->setQuery(" SELECT distinct qui.title AS name,   

( SELECT GROUP_CONCAT(profiles.title)

  FROM jos_jquarks_users_profiles AS users_profiles    
  LEFT JOIN jos_jquarks_profiles AS profiles ON users_profiles.profile_id = profiles.id     
  WHERE users_profiles.user_id = sessionWho.user_id ) AS profile,    
   ( SELECT sum(score) 
 FROM jos_jquarks_quizzes_answersessions     

  WHERE quizsession_id = quizSession.id              AND status <> -1 ) AS score, 

( SELECT count(distinct question_id)              FROM jos_jquarks_quizzes_answersessions            
  WHERE quizsession_id = quizSession.id ) AS maxScore,            
DATE_FORMAT(quizSession.finished_on,'%M %d, %Y') AS FinishedOn
 FROM jos_jquarks_quizsession AS quizSession  

LEFT JOIN jos_jquarks_users_quizzes AS users_quizzes ON users_quizzes.id = quizSession.affected_id    
LEFT JOIN jos_jquarks_quizzes AS qui ON users_quizzes.quiz_id = qui.id     
LEFT JOIN jos_jquarks_quizzes_answersessions AS quizSessAns ON quizSessAns.quizsession_id = quizSession.id 
LEFT JOIN jos_jquarks_sessionwho AS sessionWho ON sessionWho.session_id = quizSession.id        
LEFT JOIN jos_jquarks_users_profiles AS users_profiles ON users_profiles.user_id = sessionWho.user_id 
LEFT JOIN jos_jquarks_profiles AS profiles ON profiles.id = users_profiles.profile_id   
WHERE sessionWho.user_id =  ' .$id  " ) ;


if (!$database->query()) { //write data and if error occurs alert
    echo "<script> alert('".$database->getErrorMsg()."'); </script>";
}

//var_dump($database);
$tableStyle = "padding: 5px;border:1px"; 
$tdStyle = "padding:5px "; 
$thStyle = "padding:7px ";

echo '<table style="' . $tableStyle . '" cellpadding="7" cellspacing="7">'; 
echo "<tr> <th style=align:center>Quiz Title </th><th style=align:center> Score </th><th>Maximum Score </th><th> Unanswered </th> <th>Finished On </th></tr>"; 

$row = $database->loadRowList();
foreach($row as $valuearray)
{
echo '<tr style=" align="center">';
foreach($valuearray as $field)
{

echo "<td>$field</td>";
}
echo "</tr>";
}
echo "</table>";

?>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

临走之时 2024-12-06 21:35:38

这通常意味着您的查询中存在错误,并且它没有返回任何结果,因此没有对象可以通过 foreach 运行。调试此问题的最简单方法是从 joomla 管理员面板(位于全局设置 -> 系统中)打开调试模式,然后转到引发此错误的页面,它应该显示 SQL 错误。

无论如何,查看查询我能找到的唯一错误(假设所有字段/表都正确)是最后你有:

WHERE sessionWho.user_id =  ' .$id  " ) ;

这应该是:

WHERE sessionWho.user_id = $id " ) ;

WHERE sessionWho.user_id = ". intval($id)  ) ;

This typically means that there is an error in your query, and it's not returning any results so there is no object to run through the foreach. The easiest way to debug this is to turn on debug mode from the joomla administrator panel (it's in global settings -> system), and then going to the page this error is being thrown, and it should show the SQL error.

Anyway, looking at the query the only error I can find (assuming all fields/tables are correct) is that at the end you have:

WHERE sessionWho.user_id =  ' .$id  " ) ;

This should be:

WHERE sessionWho.user_id = $id " ) ;

or

WHERE sessionWho.user_id = ". intval($id)  ) ;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文