Пример кода:
$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, который представляет собой то, что они есть, но также может быть довольно запутанным, так как они выглядят настолько похожими друг на друга. Итак, вот мои вопросы:
Цикл while действительно необходим, только если вы ожидаете возвращения нескольких строк. Если вы просто получаете одну строку, вы можете просто использовать mysql_fetch_array().
$query = "SOME SQL";
$result = mysql_query($query);
$row = mysql_fetch_array($result);
Для возврата по одной строке используется стандарт. Конечно, это немного неудобно делать это на PHP, но по крайней мере у вас есть процесс, разбитый на отладочные шаги.
Использовать 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();
}
?>
Если вы не устарели от него существующей кодовой базой. DONT используйте расширение 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
}