PHP Conference Japan 2024

mysql_list_fields

(PHP 4, PHP 5)

mysql_list_fields列出 MySQL 表字段

警告

此函数在 PHP 5.4.0 中已弃用,并且它和整个 原始 MySQL 扩展 在 PHP 7.0.0 中已被移除。请改用积极开发的 MySQLiPDO_MySQL 扩展。另请参见 MySQL:选择 API 指南。此函数的替代方法包括

  • SQL 查询:SHOW COLUMNS FROM sometable

描述

mysql_list_fields(字符串 $database_name, 字符串 $table_name, 资源 $link_identifier = NULL): 资源

检索有关给定表名称的信息。

此函数已弃用。最好使用 mysql_query() 来发出 SQL SHOW COLUMNS FROM table [LIKE 'name'] 语句。

参数

database_name

正在查询的数据库的名称。

table_name

正在查询的表的名称。

link_identifier

MySQL 连接。如果未指定链接标识符,则假定为 mysql_connect() 最近打开的链接。如果找不到此类链接,它将尝试创建一个链接,就像 mysql_connect() 被调用且没有参数一样。如果找不到或建立连接,则会生成 E_WARNING 级别错误。

返回值

成功时返回结果指针 资源,失败时返回 false

返回的结果可与 mysql_field_flags()mysql_field_len()mysql_field_name()mysql_field_type() 一起使用。

示例

示例 #1 已弃用 mysql_list_fields() 的替代方法

<?php
$result
= mysql_query("SHOW COLUMNS FROM sometable");
if (!
$result) {
echo
'无法执行查询:' . mysql_error();
exit;
}
if (
mysql_num_rows($result) > 0) {
while (
$row = mysql_fetch_assoc($result)) {
print_r($row);
}
}
?>

以上示例将输出类似以下内容

Array
(
    [Field] => id
    [Type] => int(7)
    [Null] =>  
    [Key] => PRI
    [Default] =>
    [Extra] => auto_increment
)
Array
(
    [Field] => email
    [Type] => varchar(100)
    [Null] =>
    [Key] =>
    [Default] =>
    [Extra] =>
)

注释

注意:

为了向后兼容,可以使用以下已弃用的别名:mysql_listfields()

参见

添加注释

用户贡献的注释 3 个注释

mbevan at marginsoftware dot com
21 年前
如果您愿意使用大量函数来获取有关表中字段的一点点信息,那么此函数适合您。如果您只想获取所有可以找到的信息,可以使用以下方法

<?php

// 取自:http://ca.php.net/manual/en/function.mysql-field-flags.php
// 原作者:amir at scrounch dot com
// 返回表的主键中的字段名称。
// 还按 KEY 顺序保留字段。方便。
function getPrimaryKeyOf($table) {
$keys = Array();

$query = sprintf("SHOW KEYS FROM `%s`", $table);
$result = mysql_query($query) or die(mysql_error());

while (
$row = mysql_fetch_assoc($result)) {
if (
$row['Key_name'] == 'PRIMARY' )
$keys[$row['Seq_in_index'] - 1] = $row['Column_name'];
}

return
$keys;
}

// 返回有关表的大量信息...
// 如果有,自动递增字段的名称,主键中的字段(使用上面的函数),以及所有字段的所有信息。
function getTableInformationOf($table) {
$information = array(
"auto" => "",
"primary" => array(),
"fields" => array()
);

$information['primary'] = $this->getPrimaryKeyOf($table);

$result = mysql_query("DESC `$table`");
while (
$field = mysql_fetch_assoc($result) ) {
$information['fields'][] = $field;
if (
$field['Extra'] == "auto_increment" )
$information['auto'] = $field['Field'];
}

return
$information;
}

?>
rhyous at yahoo dot com
19 年前
要创建一个包含表中列名称的数组,可以使用以下简单的脚本:(注意:使用具有三个列的 table1)

<?php
$qColumnNames
= mysql_query("SHOW COLUMNS FROM table1",$db) or die("mysql 错误");
$numColumns = mysql_num_rows($qColumnNames);
$x = 0;
while (
$x < $numColumns)
{
$colname = mysql_fetch_row($qColumnNames);
$col[$colname[0]] = $colname[0];
$x++;
}

print_r($col);

/* 输出结果如下:
Array (
[firstcolumn] => firstcolumn
[secondcolumn] => secondcolumn
[thirdcolumn] => thirdcolumn
)
*/
?>

或者您可以将列从零开始编号。这在与 mysql_fetch_row 结合使用以获取数组时很有帮助。您不必记住特定列的数组编号。

<?php
$qColumnNames
= mysql_query("SHOW COLUMNS FROM table1",$db) or die("mysql 错误");
$numColumns = mysql_num_rows($qColumnNames);
$x = 0;
while (
$x < $numColumns)
{
$colname = mysql_fetch_row($qColumnNames);
$col[$colname[0]] = $x;
$x++;
}

print_r($col);

/* 输出结果如下:
Array (
[firstcolumn] => 0
[secondcolumn] => 1
[thirdcolumn] => 2
)
*/
?>

与 mysql_fetch_row 结合使用

<?php
$row
= mysql_fetch_row("SELECT * from table1",$db) or die("mysql 错误");
?>

现在您可以调用 $row[col[firstcolumn]]。当您有很多列时,这将变得非常有用。
phpflow at gmail dot com
12 年前
以下脚本用于获取表的所有列信息。当我们使用自定义 ORM 时,需要将列名与数组键匹配。

<?php
function getColoumn($table) {
$result = mysql_query("SHOW COLUMNS FROM ". $table);
if (!
$result) {
echo
'无法执行查询:' . mysql_error();
}
$fieldnames=array();
if (
mysql_num_rows($result) > 0) {
while (
$row = mysql_fetch_assoc($result)) {
$fieldnames[] = $row['Field'];
}
}

return
$fieldnames;
}
?>
To Top