点击循环php中的数据库

点击循环php中的数据库,php,mysql,database-connection,Php,Mysql,Database Connection,我对PHP非常陌生。我只是创建一个简单的页面,从数据库中获取数据并生成XML。有两个表,一个有竞争对手表,第二个有这些竞争对手的排名,因此我能够获取候选数据,当我循环到此数据并尝试在循环中再次命中DB时,得到以下错误: 未定义变量:mysqli in 致命错误:在中对空成员函数查询的调用 我试过几次,但都没用。这是我的密码: <?php /** create XML file */ $mysqli = new mysqli("localhost", "root", "******", "

我对PHP非常陌生。我只是创建一个简单的页面,从数据库中获取数据并生成XML。有两个表,一个有竞争对手表,第二个有这些竞争对手的排名,因此我能够获取候选数据,当我循环到此数据并尝试在循环中再次命中DB时,得到以下错误:

未定义变量:mysqli in

致命错误:在中对空成员函数查询的调用

我试过几次,但都没用。这是我的密码:

<?php
/** create XML file */ 
$mysqli = new mysqli("localhost", "root", "******", "****");
/* check connection */
if ($mysqli->connect_errno) {
   echo "Connect failed ".$mysqli->connect_error;
   exit();
}else{
}
$query = "select * from competitors where eventid=290 order by 1 desc LIMIT 0, 10;";
$booksArray = array();
if ($result = $mysqli->query($query)) {
/* fetch associative array */
   while ($row = $result->fetch_assoc()) {
   array_push($booksArray, $row);
  }
   if(count($booksArray)){
createXMLfile($booksArray);

 }
/* free result set */
   $result->free();
}
function createXMLfile($booksArray){
   $filePath = 'book.xml';
   $dom     = new DOMDocument('1.0', 'utf-8'); 
   $root      = $dom->createElement('books'); 
   for($i=0; $i<count($booksArray); $i++){
$eventid        =  $booksArray[$i]['eventid'];  
 $fee      =  $booksArray[$i]['fee']; 
$competitorid_system    =  $booksArray[$i]['competitorid'];
$datetimeentered     =  $booksArray[$i]['datemodified']; 
// $bookISBN      =  $booksArray[$i]['ISBN']; 
//  $bookCategory  =  $booksArray[$i]['category'];  
$book = $dom->createElement('book');
 $book->setAttribute('eventid', $eventid);
$name     = $dom->createElement('fee', $fee); 
$book->appendChild($name); 
$author   = $dom->createElement('competitorid_system', $competitorid_system); 

 $book->appendChild($author); 

 $price    = $dom->createElement('datetimeentered', $datetimeentered); 

$book->appendChild($price); 

// fetch other data
$query = "select * from ranking where eventid=290 and competitorid=".$competitorid_system;;

 echo "Query".$query;
   //exit();
$booksRankingArray = array();
if ($result = $mysqli->query($query)) {
/* fetch associative array */
while ($row = $result->fetch_assoc()) {
array_push($booksRankingArray, $row);
}
if(count($booksRankingArray)){
createXMLfile($booksRankingArray);
 }
/* free result set */
$result->free();
}
$root->appendChild($book);
}
$dom->appendChild($root); 
$dom->save($filePath); 
} 
/* close connection */
$mysqli->close();
$mysqli变量超出createXMLfile的作用域

变量的范围是定义变量的上下文。大多数情况下,所有PHP变量都只有一个作用域。这个单一作用域也跨越了包含的和必需的文件

若要解决此问题,请将函数签名更改为

function createXMLfile($mysqli, $booksArray)
{ 
    // … rest of code …
}
然后将变量从外部范围传递到函数范围:

$mysqli = new mysqli("localhost", "root", "******", "****");
$booksArray = array();    
createXMLfile($mysqli, $booksArray);
还可以使用全局变量从全局范围中引入变量:

function createXMLfile($booksArray)
{ 
    global $mysqli;
    // … rest of code …    
}

因为它会导致代码紧密耦合,使代码不容易推理。

请正确缩进代码。当缩进是完全随机的时候,阅读和遵循代码是非常困难的argument@BNT,我只是试着用传球作为论据,结果成功了。破坏性,谢谢你的回答,我用这种方式,它起作用了….: