示例代码:
$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,它们代表它们是什么,但也可能很混乱,因为它们看起来非常相似。所以这是我的问题:
答案 0 :(得分:1)
如果您希望返回多行,则只需要while循环。如果你只是获得一行,你可以简单地使用mysql_fetch_array()。
$query = "SOME SQL";
$result = mysql_query($query);
$row = mysql_fetch_array($result);
对于单行返回是我使用的标准。当然,在PHP中执行此操作有点笨拙,但至少您可以将该过程分解为可调试的步骤。
答案 1 :(得分:0)
除非您通过现有代码库将其附加到其中。不要使用mysql
扩展名。使用PDO
或Mysqli
。 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();
}
?>