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 $row[‘cid‘].‘::‘.$row[1].‘<br>‘;
}
$result = mysql_query($sql);
while($row = mysql_fetch_array($result))
{
echo $row[‘cid‘].‘::‘.$row[1].‘<br>‘;
}
$result = mysql_query($sql);
while($row = mysql_fetch_object($result))
{
echo $row->cid.‘::‘.$row->title.”<br>”;
}
$result = mysql_query($sql);
while($row = mysql_fetch_assoc($result))
{
echo $row[‘cid‘].‘::‘.$row[1].‘<br>‘;
}
?> 

分析:

1.mysql_fetch_row,这个函数是从结果集中取一行作为枚举数据,从和指定的结果标识关联的结果集中取得一行数据并作为数组返回。每个结果的列储存在一个数组的单元中,偏移量从 0 开始。 注意,这里是从0开始偏移,也就是说不能用字段名字来取值,只能用索引来取值,所以如下代码是取不到值的: 
while($row = mysql_fetch_row($res)){ echo $row[‘cid‘].‘::‘.$row[1].”; } //这里的$row[‘cid‘] 取不到值。

2.mysql_fetch_array,从结果集中取得一行作为关联数组,或数字数组,或二者兼有,除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。 也就是说他得到的结果像数组一样,可以用key或者索引来取值,所以 
while($row = mysql_fetch_array($res)){ echo $row[‘cid‘].‘::‘.$row[1].”; }//这里$row[‘cid‘],$row[1]都能得到相应的值。

3.mysql_fetch_object,顾名思义,从结果集中取得一行作为对象,并将字段名字做为属性。所以只有这样才能取到值 
while($row = mysql_fetch_object($res)){ echo $row->cid.‘::‘.$row->title.”"; }

4.mysql_fetch_assoc,从结果集中取得一行作为关联数组,也就是说这个函数不能像mysql_fetch_row那样用索引来取值,只能用字段名字来取,所以 
while($row = mysql_fetch_assoc($res)){ echo $row[‘cid‘].‘::‘.$row[1].”; } //$row[1]这样是取不到值的

补充一点: mysql_fetch_array函数是这样定义的:array mysql_fetch_array ( resource result [, int result_type]),返回根据从结果集取得的行生成的数组,如果没有更多行则返回 FALSE。 mysql_fetch_array() 中可选的第二个参数 result_type 是一个常量,可以接受以下值:
MYSQL_ASSOC,
MYSQL_NUM , 
MYSQL_BOTH。

其中: 
1、mysql_fetch_assoc($result)==mysql_fetch_array($result,MYSQL_ASSOC); 
2、mysql_fetch_row($result)==mysql_fetch_array($result,MYSQL_NUM);
所以mysql_fetch_array()函数在某种程度上可以算是mysql_fetch_row()与 mysql_fetch_assoc()的集合。

另外,mysql_fetch_array()另外还有MYSQL_BOTH参数,将得到一个同时包含关 联和数字索引的数组。

在来说句 $row = $db->fetch_array($query); $db是从数据库操作类,$db->fetch_array($query),fetch_array($query)是那个db类里的方法,$row = $db->fetch_array($query)这句的意思是从记录集$query中得到数据库中的一行记录。 不用类可这样实现 复制代码 代码如下:

[email protected]_connect($host,$user,$pass);
@mysql_select_db($database,$conn);
$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){ $rows[]=$row; }

一般情况下我喜欢用mysql_fetch_object,因为他返回的是一个对象.$row->title要比.$row[0],.$row[‘title‘]更加清晰明了。

时间: 2024-10-29 05:40:49

mysql_fetch_row,mysql_fetch_array,mysql_fetch_object,mysql_fetch_assoc的区别!的相关文章

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]

mysql_fetch_row mysql_fetch_array

1 mysql_fetch_row  mysql_fetch_array 1.1 mysql_fetch_row <?php while($row = mysql_fetch_row($result)){ $n=0; ?> <b><span style=""> <?php if($n==0){ echo $row [14]; ?> 1.2 mysql_fetch_array 注释:mysql_fetch_array() 是 mysql_f

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_

【转】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_array 和 mysql_fetch_assoc 的区别

mysql_fetch_assoc 得到的是关联数组.mysql_fetch_array 可以得到关联数组也可以得到索引数组,或者二者都有. 假如从数据库教程取出一个用户的用户名和密码username   passwordtest       123456用assoc  结果是array([username]=>'test',[password]=>'123456')用array  根据参数不同结果可能是以下三种之一         array([username]=>'test',[p

php操作mysql小结

<?php //连接数据库 //设置文档显示编码 header('Content-type:text/html;charset=utf-8'); if($con=mysql_connect('localhost','root','1234')){//返回连接标识符 echo '连接成功<br>'; }else{ echo '连接失败<br>'; } //选择数据库 if(mysql_select_db('mydbtest')){ echo "选择数据库成功<b

PHP与MySQL通讯那点事

在我们的一款WebGame的生产环境中,一次无意的strace抓包时,发现了php与mysql大量通讯的数据.这种情况,在游戏服务器刚启动时,是正常的,但如果是运行一段时间之后,出现大量SELECT的SQL查询,绝对是有问题的,而且,所操作的数据库并不是配置库,那意味着,我们程序员的程序出现了违规的操作.具体结果大约如下: strace跟踪php进程与mysql通讯的日志(点击可查看大图) 如上图所示,php持续接收读取进程内描述符为3的响应包数据,描述符为3的为php与mysql建立的TCP通

一步一步教你用PHP+MySql搭建网站 No.1 主页&amp;数据库连接

这一章节我们来看用户输入网页后的主界面. 一般来说,默认主页都是index点xxx,比如 index.php, index.html , index.jsp等等.我们来看一下我们的index.php吧 index.php 提醒: 在<?php?>的两端,不要出现任何空格或者其他字符,也就是不要在<?php 的前面加上空格这样的字符,然后?>后面也不要出现其余的字符,不然的话可能会出现这样的提示: 我之前出现过这样的情况,google了之后是说headers 必须放在最开始的时候执行

php中关于mysqli和mysql区别的一些知识点分析

看书.看视频的时候一直没有搞懂mysqli和mysql到底有什么区别.于是今晚“谷歌”一番,整理一下.需要的朋友可以参考下. 一: PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extension 而言,本身也增加了安全性.而 PDO (PHP Data Object) 则是提供了一个 Abstraction Layer 来操作资料库,用讲的其实看不出来有有什麽差别,