PHP中mysql_fetch_row()、mysql_fetch_assoc()和mysql_fetch_array()的联系

总是记不住或者混淆mysql_fetch_row()、mysql_fetch_assoc()和mysql_fetch_array()这三个函数的朋友们注意了,今天我在这里给大家总结一下他们之间的关系,希望能对大家有所帮助。

1.mysql_fetch_row() -- 从结果集中取得一行作为枚举数组

说明  array mysql_fetch_row ( resource result)

返回根据所取得的行生成的数组,如果没有更多行则返回 FALSE。

mysql_fetch_row() 从和指定的结果标识关联的结果集中取得一行数据并作为数组返回。每个结果的列储存在一个数组的单元中,偏移量从 0 开始。

依次调用 mysql_fetch_row() 将返回结果集中的下一行,如果没有更多行则返回 FALSE。

2.mysql_fetch_assoc() -- 从结果集中取得一行作为关联数组

说明  array mysql_fetch_assoc ( resource result)

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

mysql_fetch_assoc()将数据作为关联索引储存,用字段名作为键名。如果结果中的两个或以上的列具有相同字段名,最后一列将优先。要访问同名的其它列,必须用该列的数字索引或给该列起个别名。对有别名的列,不能再用原来的列名访问其内容。

3.mysql_fetch_array --从结果集中取得一行作为关联数组,或数字数组,或二者兼有

说明  array mysql_fetch_array ( resource result [, int result_type])

返回根据从结果集取得的行生成的数组,如果没有更多行则返回 FALSE。

mysql_fetch_array() 是 mysql_fetch_row() 的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。

如果结果中的两个或以上的列具有相同字段名,最后一列将优先。要访问同名的其它列,必须用该列的数字索引或给该列起个别名。对有别名的列,不能再用原来的列名访问其内容。

有一点很重要必须指出,用 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()那样)。

注: 该函数返回的字段名是大小写敏感的。

时间: 2024-10-14 20:32:27

PHP中mysql_fetch_row()、mysql_fetch_assoc()和mysql_fetch_array()的联系的相关文章

php中mysql_fetch_row() 和mysql_fetch_array之间有什么区别

mysql_fetch_row是从结果集取出1行数组,作为枚举 mysql_fetch_array是从结果集取出一行数组作为关联数组,或数字数组,两者兼得eg:$sql="select abc,def from a";$res=mysql_query($sql); 那么:$row=mysql_fetch_row($res);$row结果是两个:$row[0]和$row[1]那么:$row=mysql_fetch_array($res);$row结果是4个:$row[0].$row[1]

PHP中mysql_fetch_row 和 mysql_fetch_array()的区别与使用

mysql_fetch_row() 从和指定的结果标识关联的结果集中取得一行数据并作为数组返回.每个结果的列储存在一个数组的单元中,偏移量从 0 开始. 依次调用 mysql_fetch_row() 将返回结果集中的下一行,如果没有更多行则返回 FALSE. 1 <?php 2 $result = mysql_query("SELECT id,email FROM people WHERE id = '42'"); 3 if (!$result) { 4 echo 'Could

43)PHP,mysql_fetch_row 和mysql_fetch_assoc和mysql_fetch_array

mysql_fetch_row   提取的结果是没有查询中的字段名了(也就是没有键id,GoodsName,只有值),如下图: mysql_fetch_assoc 提取的结果有键值,如下图: mysql_fetch_array提取的结果有键值,是前面两种的综合,如下图:

mysql_fetch_array,mysql_fetch_row,mysql_fetch_assoc区别

array  mysql_fetch_array ( result   [, int result_type]  ) 返回:根据从结果集取得的行生成的数组,如果没有更多行则返回 FALSE. int result_type的值: 1:MYSQL_ASSOC    //完全等同于 mysql_fetch_assoc($result) 2:MYSQL_NUM        //完全等同于 mysql_fetch_row($result) 3:MYSQL_BOTH     //默认,得到一个同时包含关

【转】mysql_fetch_row , mysql_fetch_array , mysql_fetch_assoc 的区别

<?php $link = mysql_connect('localhost', 'root', ”); mysql_select_db('abc', $link); $sql = “select * from book”; $result = mysql_query($sql); while($row = mysql_fetch_row($result)) { echo $row['cid'].'::'.$row[1].'<br>'; } $result = mysql_query($

mysql_fetch_row,mysql_fetch_array,mysql_fetch_object,mysql_fetch_assoc的区别!

php从mysql中访问数据库并取得数据,取得结果的过程中用到好几个类似的方法,区别及用法值得区分一下,看下面的代码 代码如下: <?php $link=mysql_connect('localhost','root',”); mysql_select_db('abc',$link); $sql = “select * from book”; $result = mysql_query($sql); while($row = mysql_fetch_row($result)) { echo $r

mysql_fetch_row,mysql_fetch_array,mysql_fetch_assoc的区别

一直以来,有很多初学者搞不懂这些Mysql中从查询结果集中取得数据的函数之间有什么区别,今天我就来秀一把,在秀之前先给大家一段PHP实例 代码如下: <?php $link=mysql_connect('localhost','root',"); mysql_select_db('abc',$link); $sql = "select * from book"; $result = mysql_query($sql); while($row = mysql_fetch_

PHP面试题

1.不用新变量直接交换现有两个变量的值 (1)list($a,$b)=array($b,$a);(2)a=a+b,b=a-b,a=a-b 2.PHP数字金额转大小格式,同时说明思路 function daxie($num){ $da_num = array('零','一','二','三','四','五','六','七','八','九'); $return = ''; $len_num = strlen($num); if(!is_numeric($num) || $len_num < 0){ r

PHP知识大全【基础】

1. 变量如何定义?如何检查变量是否定义?如何删除一个变量?怎样检测变量是否设置? $定义  isset()// 检测变量是否设置 defined()// 检测常量是否设置 unset()//销毁指定的变量 empty()// 检测变量是否为空 2. 什么是可变变量? 一个变量的变量名可以动态的设置和使用. $a = 'hello' , $$a = 'world',  ${$a}=hello world 3. 变量赋值方式有哪几种? 1)直接赋值   2)变量间赋值   3)引用赋值 4. 引用