mysql_fetch_row(),mysql_fetch_array(),mysql_fetch_assoc()的区别

mysql_fetch_row(),mysql_fetch_array(),mysql_fetch_assoc()

<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<?php
//phpinfo();

$con=mysql_connect('localhost','root','');
mysql_set_charset('utf8',$con);
mysql_select_db('manage',$con);

static $arr=array();
$test=array('row','array','assoc');
foreach($test as $k=>$v){
    $res=mysql_query('select * from kim_check',$con) or die(mysql_error());
    switch($v){
        case 'row':
          while($row=mysql_fetch_row($res)){
                    $arr[$v][]=$row;
                }
                break;
        case 'array':
          while($row=mysql_fetch_array($res,MYSQL_NUM)){//或者$row=mysql_fetch_array($res,MYSQL_NUM)
                    $arr[$v][]=$row;
                }
                break;
        case 'assoc':
          while($row=mysql_fetch_assoc($res)){
                    $arr[$v][]=$row;
                }
                break;
    }
    mysql_free_result($res);
}


print_r($arr);

/*mysql_fetch_row
返回根据所取得的行生成的数组,如果没有更多行则返回 FALSE。
mysql_fetch_row()从和指定的结果标识关联的结果集中取得一行数据并作为数组返回。每个结果的列储存在一个数组的单元中,偏移量从 0 开始。
依次调用 mysql_fetch_row()将返回结果集中的下一行,如果没有更多行则返回 FALSE。
*/

/*
mysql_fetch_array() 是 mysql_fetch_row()的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。
如果结果中的两个或以上的列具有相同字段名,最后一列将优先。要访问同名的其它列,必须用该列的数字索引或给该列起个别名。对有别名的列,不能再用原来的列名访问其内容(本例中的 'field')。
有一点很重要必须指出,用 mysql_fetch_array()并不明显 比用 mysql_fetch_row()慢,而且还提供了明显更多的值。
mysql_fetch_array()中可选的第二个参数 result_type是一个常量,可以接受以下值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。本特性是 PHP 3.0.7 起新加的。本参数的默认值是 MYSQL_BOTH。
如果用了 MYSQL_BOTH,将得到一个同时包含关联和数字索引的数组。用 MYSQL_ASSOC 只得到关联索引(如同 mysql_fetch_assoc() 那样),用 MYSQL_NUM 只得到数字索引(如同 mysql_fetch_row() 那样)。
*/

/*mysql_fetch_assoc()
返回根据从结果集取得的行生成的关联数组,如果没有更多行则返回 FALSE。

mysql_fetch_assoc() 和用 mysql_fetch_array() 加上第二个可选参数 MYSQL_ASSOC 完全相同。它仅仅返回关联数组。这也是 mysql_fetch_array()起初始的工作方式。如果在关联索引之外还需要数字索引,用 mysql_fetch_array()。

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

有一点很重要必须指出,用 mysql_fetch_assoc()并不明显 比用 mysql_fetch_row()慢,而且还提供了明显更多的值。
*/

?>