PHPerKaigi 2025

mysql_fetch_assoc

(PHP 4 >= 4.0.3, PHP 5)

mysql_fetch_assoc 从结果集中取得一行作为关联数组

警告

本扩展自 PHP 5.5.0 起已废弃,并在自 PHP 7.0.0 开始被移除。应使用 MySQLiPDO_MySQL 扩展来替换之。参见 MySQL:选择 API 指南来获取更多信息。用以替代本函数的有:

说明

mysql_fetch_assoc(resource $result): array

返回对应结果集的关联数组,并且继续移动内部数据指针。 mysql_fetch_assoc() 和用 mysql_fetch_array() 加上第二个可选参数 MYSQL_ASSOC 完全相同。它仅仅返回关联数组。

参数

result

resource 型的结果集。此结果集来自对 mysql_query() 的调用。

返回值

返回根据从结果集取得的行生成的关联数组;如果没有更多行则返回 false

如果结果中的两个或以上的列具有相同字段名,最后一列将优先。要访问同名的其它列,要么用 mysql_fetch_row() 来取得数字索引或给该列起个别名。 参见 mysql_fetch_array() 例子中有关别名说明。

示例

示例 #1 扩展的 mysql_fetch_assoc() 例子

<?php

$conn
= mysql_connect("localhost", "mysql_user", "mysql_password");

if (!
$conn) {
echo
"Unable to connect to DB: " . mysql_error();
exit;
}

if (!
mysql_select_db("mydbname")) {
echo
"Unable to select mydbname: " . mysql_error();
exit;
}

$sql = "SELECT id as userid, fullname, userstatus
FROM sometable
WHERE userstatus = 1"
;

$result = mysql_query($sql);

if (!
$result) {
echo
"Could not successfully run query ($sql) from DB: " . mysql_error();
exit;
}

if (
mysql_num_rows($result) == 0) {
echo
"No rows found, nothing to print so am exiting";
exit;
}

// While a row of data exists, put that row in $row as an associative array
// Note: If you're expecting just one row, no need to use a loop
// Note: If you put extract($row); inside the following loop, you'll
// then create $userid, $fullname, and $userstatus
while ($row = mysql_fetch_assoc($result)) {
echo
$row["userid"];
echo
$row["fullname"];
echo
$row["userstatus"];
}

mysql_free_result($result);

?>

注释

注意: 性能

必须指出一个要点: mysql_fetch_assoc()mysql_fetch_row()不明显 慢,而且还提供了更多有用的值。

注意: 此函数返回的字段名大小写敏感

注意: 此函数将 NULL 字段设置为 PHP null 值。

参见

添加备注

用户贡献的备注 6 notes

up
5
marREtijn dot posthMOuma at hoVEme dot nl
21 years ago
It appears that you can't have table.field names in the resulting array.
Just use an alias if your results come up empty and you are using multi-table query's:

$res=mysql_query("SELECT user.ID AS uID, order.ID AS oID FROM user, order WHERE ( order.userid=uID )";
while ($row=mysql_fetch_assoc($res)) {
echo "<p>userid: $row['uID'], orderid: $row['oID']</p>";
}
up
5
joe at kybert dot com
20 years ago
Worth pointing out that the internal row pointer is incremented once the data is collected for the current row.

This means that multiple calls will iterate through the row data, so you DONT need to mysql_data_seek(..) between calls.

This is noted in the mysql_fetch_row() docs, but not here!?
up
0
Typer85 at gmail dot com
18 years ago
Please be advised that the resource result that you pass to this function can be thought of as being passed by reference because a resource is simply a pointer to a memory location.

Because of this, you can not loop through a resource result twice in the same script before resetting the pointer back to the start position.

For example:

----------------
<?php

// Assume We Already Queried Our Database.

// Loop Through Result Set.

while( $queryContent = mysql_fetch_row( $queryResult ) {

// Display.

echo $queryContent[ 0 ];
}

// We looped through the resource result already so the
// the pointer is no longer pointing at any rows.

// If we decide to loop through the same resource result
// again, the function will always return false because it
// will assume there are no more rows.

// So the following code, if executed after the previous code
// segment will not work.

while( $queryContent = mysql_fetch_row( $queryResult ) {

// Display.

echo $queryContent[ 0 ];
}

// Because $queryContent is now equal to FALSE, the loop
// will not be entered.

?>
----------------

The only solution to this is to reset the pointer to make it point at the first row again before the second code segment, so now the complete code will look as follows:

----------------
<?php

// Assume We Already Queried Our Database.

// Loop Through Result Set.

while( $queryContent = mysql_fetch_row( $queryResult ) {

// Display.

echo $queryContent[ 0 ];
}

// Reset Our Pointer.

mysql_data_seek( $queryResult );

// Loop Again.

while( $queryContent = mysql_fetch_row( $queryResult ) {

// Display.

echo $queryContent[ 0 ];
}

?>
----------------

Of course you would have to do extra checks to make sure that the number of rows in the result is not 0 or else mysql_data_seek itself will return false and an error will be raised.

Also please note that this applies to all functions that fetch result sets, including mysql_fetch_row, mysql_fetch_assos, and mysql_fetch_array.
up
-3
george at georgefisher dot com
15 years ago
Thanks to to R. Bradley for the implode idea. The following fixes a few bugs and includes quote_smart functionality (and has been tested)

<?php
function mysql_insert_assoc ($my_table, $my_array) {

//
// Insert values into a MySQL database
// Includes quote_smart code to foil SQL Injection
//
// A call to this function of:
//
// $val1 = "foobar";
// $val2 = 495;
// mysql_insert_assoc("tablename", array(col1=>$val1, col2=>$val2, col3=>"val3", col4=>720, col5=>834.987));
//
// Sends the following query:
// INSERT INTO 'tablename' (col1, col2, col3, col4, col5) values ('foobar', 495, 'val3', 720, 834.987)
//

global $db_link;

// Find all the keys (column names) from the array $my_array
$columns = array_keys($my_array);

// Find all the values from the array $my_array
$values = array_values($my_array);

// quote_smart the values
$values_number = count($values);
for (
$i = 0; $i < $values_number; $i++)
{
$value = $values[$i];
if (
get_magic_quotes_gpc()) { $value = stripslashes($value); }
if (!
is_numeric($value)) { $value = "'" . mysql_real_escape_string($value, $db_link) . "'"; }
$values[$i] = $value;
}

// Compose the query
$sql = "INSERT INTO $my_table ";

// create comma-separated string of column names, enclosed in parentheses
$sql .= "(" . implode(", ", $columns) . ")";
$sql .= " values ";

// create comma-separated string of values, enclosed in parentheses
$sql .= "(" . implode(", ", $values) . ")";

$result = @mysql_query ($sql) OR die ("<br />\n<span style=\"color:red\">Query: $sql UNsuccessful :</span> " . mysql_error() . "\n<br />");

return (
$result) ? true : false;
}
?>
up
-4
R. Bradley
18 years ago
In response to Sergiu's function - implode() would make things a lot easier ... as below:

<?php
function mysql_insert_assoc ($my_table, $my_array) {

// Find all the keys (column names) from the array $my_array
$columns = array_keys($my_array);

// Find all the values from the array
$values = array_values($my_array);

// We compose the query
$sql = "insert into `$my_table` ";
// implode the column names, inserting "\", \"" between each (but not after the last one)
// we add the enclosing quotes at the same time
$sql .= "(\"" . implode("\", \"", $column_names) . "\")";
$sql .= " values ";
// Same with the values
$sql .= "(" . implode(", ", $values) . ")";

$result = mysql_query($sql);

if (
$result)
{
echo
"The row was added sucessfully";
return
true;
}
else
{
echo (
"The row was not added<br>The error was" . mysql_error());
return
false;
}
}
?>

Thus, a call to this function of:
mysql_insert_assoc("tablename", array("col1"=>"val1", "col2"=>"val2"));

Sends the following sql query to mysql:
INSERT INTO `tablename` ("col1", "col2") VALUES ("val1", "val2")
up
-5
benlanc at ster dot me dot uk
19 years ago
It probably without saying, but using list() in conjunction with mysql_fetch_assoc() does not work - use mysql_fetch_row() instead.

<?php
$sql
= "SELECT `id`,`field`,`value` FROM `table`";
$result = mysql_query($sql);

// this results in empty values for rowID,fieldName,myValue
list($rowID,$fieldName,$myValue) = mysql_fetch_assoc($result);

// this is what you want:
list($rowID,$fieldName,$myValue) = mysql_fetch_row($result);
?>
To Top