mysql_fetch_row()、mysql_fetch_assoc()及mysql_fetch_array() 的使用区别

739次阅读
没有评论

共计 1251 个字符,预计需要花费 4 分钟才能阅读完成。

很多同学对于 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()那样)。

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

正文完
 0