О процедуре mysql_query -> mysql_fetch_array ()

0

Пример кода:

$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
    Цикл while гарантирует, что вы получите все результаты, возвращаемые mysql, ЕСЛИ ваш предыдущий sql вернул более одного совпадения. Таким образом, вы не можете пропустить их, в противном случае неполный
Теги:
coding-style

3 ответа

1

Цикл while действительно необходим, только если вы ожидаете возвращения нескольких строк. Если вы просто получаете одну строку, вы можете просто использовать mysql_fetch_array().

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

Для возврата по одной строке используется стандарт. Конечно, это немного неудобно делать это на PHP, но по крайней мере у вас есть процесс, разбитый на отладочные шаги.

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();
}
?>
0

Если вы не устарели от него существующей кодовой базой. 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
}
  • 0
    Я никогда не слышал о PDO. Не могли бы вы предоставить ссылку?
  • 0
    @Shawn: PHP документы - php.net/manual/en/book.pdo.php

Ещё вопросы

Сообщество Overcoder
Наверх
Меню