关于mysql_query - > mysql_fetch_array()程序

时间:2010-12-01 17:08:47

标签: php mysql sql coding-style

示例代码:

$infoArray = array();
require_once("connectAndSelect.php");
// Connects to mysql and selects the appropriate database
$sql = "SOME SQL";
if($results = mysql_query($sql))
{
    while($result = mysql_fetch_array($results, MYSQL_ASSOC))
    {
        $infoArray[] = $result;
    }
}
else
{
    // Handle error
}
echo("<pre>");
print_r($infoArray);
echo("</pre>");

在这个示例代码中,我只想在$ infoArray中获取查询结果。简单的任务,简单的措施......不是。 我会喜欢这样的事情:

$sql = "SOME SQL";
$infoArray = mysql_results($sql);

但不,正如你所看到的,我有两个额外的变量和一个我不太关心的while循环。他们实际上没有做任何事情:我永远不会再使用它们了。此外,我永远不知道怎么称呼他们。在这里,我使用$ results和$ result,它们代表它们是什么,但也可能很混乱,因为它们看起来非常相似。所以这是我的问题:

  1. 我有更简单的方法吗? 不知道这种情况 任务?
  2. 如果没有,你有什么名字 给那些一次性变量?是 有标准吗?

3 个答案:

答案 0 :(得分:1)

如果您希望返回多行,则只需要while循环。如果你只是获得一行,你可以简单地使用mysql_fetch_array()。

$query = "SOME SQL";
$result = mysql_query($query);
$row = mysql_fetch_array($result);

对于单行返回是我使用的标准。当然,在PHP中执行此操作有点笨拙,但至少您可以将该过程分解为可调试的步骤。

答案 1 :(得分:0)

除非您通过现有代码库将其附加到其中。不要使用mysql扩展名。使用PDOMysqli。 PDO是两者中的首选。

你的例子可以是PDO的一套非常简明的陈述:

// create a connection this could be done in your connection include
$db = new PDO('mysql:host=localhost;dbname=your_db_name', $user, $password);

// for the first or only result
$infoArray = $db->query('SOME SQL')->fetch(PDO::FETCH_ASSOC);

// if you have multiple results and want to get them all at once in an array
$infoArray = $db->query('SOME SQL')->fetchAll(PDO::FETCH_ASSOC);

   // if you have multiple results and want to use buffering like you would with mysql_result
   $stmt =  $db->query('SOME SQL');
   foreach($stmt as $result){
     // use your result here
   }

但是,如果查询中现在存在变量,则只应使用上述内容。如果有变量需要转义...最简单的处理方法是使用准备好的声明:

$stmt = $db->prepare('SELECT * FROM some_table WHERE id = :id');
$stmt->execute(array(':id' => $id));

// get the first result
$infoArray = $stmt->fetch(PDO::FETCH_ASSOC);

// loop through the data as a buffered result set
while(false !== ($row = $stmt->fetch(PDO::FETCH_ASSOC))){
   // do stuff with $row data
}

答案 2 :(得分:0)

使用PDO:

<?php

/*** mysql hostname ***/
$hostname = 'localhost';

/*** mysql username ***/
$username = 'username';

/*** mysql password ***/
$password = 'password';

try {
  $dbh = new PDO("mysql:host=$hostname;dbname=mysql", $username, $password);
  $sql = "SELECT * FROM myTable";
  $result = $dbh->query($sql)
  //Do what you want with an actual dataset
}
catch(PDOException $e) {
  echo $e->getMessage();
}
?>