php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别


Posted in PHP onAugust 08, 2012

方法名:mssql_fetch_row()

测试:

require 'dbconn.php'; 
$sql = 'select * from _Test'; 
$query = mssql_query($sql); 
while($row=mssql_fetch_row($query)) 
{ 
echo $row['UserId'].'::'.$row[1].'<br>'; 
}

返回:

Notice: Undefined index: UserId in D:/_PHP_Test/Test2/test_connLocalDB.php on line 32 ::王小一
Notice: Undefined index: UserId in D:/_PHP_Test/Test2/test_connLocalDB.php on line 32 ::王小二
Notice: Undefined index: UserId in D:/_PHP_Test/Test2/test_connLocalDB.php on line 32 ::王小三
Notice: Undefined index: UserId in D:/_PHP_Test/Test2/test_connLocalDB.php on line 32 ::王小四
Notice: Undefined index: UserId in D:/_PHP_Test/Test2/test_connLocalDB.php on line 32 ::王小五

分析:

mssql_fetch_row(),和用mssql_fetch_array()加上第二个可选参数 MYSQL_NUM 完全相同。从和指定的结果标识关联的结果集中取得一行数据并作为数组返回。每个结果的列储存在一个数组的单元中,偏移量从 0 开始。 注意,这里是从0开始偏移,不能用key值(字段名)来取值,只能用索引来取值。因此,这里使用$row['key值']无法取到值。

方法名: mssql_fetch_assoc()

测试:

$query = mssql_query($sql); 
while($row=mssql_fetch_assoc($query)) 
{ 
echo $row['UserId'].'::'.$row[1].'<br>'; 
}

返回:

Notice: Undefined offset: 1 in D:/_PHP_Test/Test2/test_connLocalDB.php on line 43 1::
Notice: Undefined offset: 1 in D:/_PHP_Test/Test2/test_connLocalDB.php on line 43 2::
Notice: Undefined offset: 1 in D:/_PHP_Test/Test2/test_connLocalDB.php on line 43 3::
Notice: Undefined offset: 1 in D:/_PHP_Test/Test2/test_connLocalDB.php on line 43 4::
Notice: Undefined offset: 1 in D:/_PHP_Test/Test2/test_connLocalDB.php on line 43 5::
分析:
mssql_fetch_assoc() 和用mssql_fetch_array()加上第二个可选参数 MYSQL_ASSOC 完全相同。它仅仅返回关联数组。这也是 mssql_fetch_array()起初始的工作方式。因此用$row[索引值]无法取到值。

方法名: mssql_fetch_array()

测试:

<?php 
$query = mssql_query($sql); 
while($row=mssql_fetch_array($query)) 
{ 
echo $row['UserId'].'::'.$row[1].'<br>'; 
} 
?>

返回:
1::王小一
2::王小二
3::王小三
4::王小四
5::王小五

分析:
mssql_fetch_array(),是mssql_fetch_row()的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。 因此这里使用$row['key值']和$row[索引值]皆可以取到值。

mssql_fetch_array() 中第二个参数result_type (这是一个常量)为可选参数,取值范围为:MYSQL_ASSOC ,MYSQL_NUM 和 MYSQL_BOTH 。其中:
mssql_fetch_array($query, MYSQL_ASSOC) == mssql_fetch_assoc($query);
mssql_fetch_array($query, MYSQL_NUM) == mssql_fetch_row($query);
所以mssql_fetch_array()函数在某种程度上可以算是mssql_fetch_row()与 mssql_fetch_assoc ()的集合。因此,mssql_fetch_array()另外还有MYSQL_BOTH参数,将得到一个同时包含关 联和数字索引的数组。

方法名: mssql_fetch_object()

测试:

$query=mssql_query($sql); 
while($row=mssql_fetch_object($query)) 
{ 
echo $row->UserId.'::'.$row->CreateTime."<br>"; 
}

返回:
1::06 7 2011 4:46PM
2::06 7 2011 4:46PM
3::06 7 2011 4:46PM
4::06 7 2011 4:46PM
5::06 7 2011 4:46PM

分析:

mysql_fetch_object() 和 mssql_fetch_array类似,只有一点区别,即返回一个对象而不是数组,并将字段名字做为属性。间接地也意味着只能通过字段名来访问,而不是偏移量。

PHP 相关文章推荐
真正的ZIP文件操作类(php)
Jul 21 PHP
PHP rawurlencode与urlencode函数的深入分析
Jun 08 PHP
PHP中nowdoc和heredoc使用需要注意的一点
Mar 21 PHP
php中convert_uuencode()与convert_uuencode函数用法实例
Nov 22 PHP
在WordPress中使用PHP脚本来判断访客来自什么国家
Dec 10 PHP
CodeIgniter配置之routes.php用法实例分析
Jan 19 PHP
php基于curl重写file_get_contents函数实例
Nov 08 PHP
10个值得深思的PHP面试题
Nov 14 PHP
Smarty日期时间操作方法示例
Nov 15 PHP
PHP新特性之字节码缓存和内置服务器
Aug 11 PHP
php伪静态验证码不显示的解决方案
Sep 26 PHP
tp5框架基于ajax实现异步删除图片的方法示例
Feb 10 PHP
php中++i 与 i++ 的区别
Aug 08 #PHP
php中判断文件空目录是否有读写权限的函数代码
Aug 07 #PHP
PHP中全局变量global和$GLOBALS[]的区别分析
Aug 06 #PHP
php一个找二层目录的小东东
Aug 02 #PHP
PHP文章采集URL补全函数(FormatUrl)
Aug 02 #PHP
PHP服务器页面间跳转实现方法
Aug 02 #PHP
php中3des加密代码(完全与.net中的兼容)
Aug 02 #PHP
You might like
dedecms 制作模板中使用的全局标记图文教程
2007/03/11 PHP
smarty的保留变量问题
2008/10/23 PHP
关于PHP 如何用 curl 读取 HTTP chunked 数据
2016/02/26 PHP
PHP通过bypass disable functions执行系统命令的方法汇总
2018/05/02 PHP
laravel框架中控制器的创建和使用方法分析
2019/11/23 PHP
关于js类的定义
2011/06/28 Javascript
javascript淡入淡出效果的实现思路
2012/03/31 Javascript
Javascript玩转继承(二)
2014/05/08 Javascript
jQuery对象的selector属性用法实例
2014/12/27 Javascript
jQuery满意度星级评价插件特效代码分享
2015/08/19 Javascript
Javascript缓存API
2016/06/14 Javascript
EasyUI Datebox 日期验证之开始日期小于结束时间
2017/05/19 Javascript
基于AngularJS实现的工资计算器实例
2017/06/16 Javascript
vue项目中的webpack-dev-sever配置方法
2017/12/14 Javascript
JavaScript实现沿五角星形线摆动的小圆实例详解
2020/07/28 Javascript
[03:09]显微镜下的DOTA2第一期——带你走进华丽的DOTA2世界
2014/06/20 DOTA
[01:31:22]Ti4 循环赛第四日附加赛LGD vs Mouz
2014/07/13 DOTA
Python函数中定义参数的四种方式
2014/11/30 Python
Python实现带参数与不带参数的多重继承示例
2018/01/30 Python
python2 与 pyhton3的输入语句写法小结
2018/09/10 Python
python 进程的几种创建方式详解
2019/08/29 Python
Python调用.NET库的方法步骤
2019/12/27 Python
Python reduce函数作用及实例解析
2020/05/08 Python
Python decimal模块使用方法详解
2020/06/08 Python
如何在网站上添加谷歌定位信息
2016/04/16 HTML / CSS
说一下Linux下有关用户和组管理的命令
2016/01/04 面试题
医学生个人求职信范文
2013/09/24 职场文书
个人自我评价范文
2014/02/05 职场文书
八项规定整改措施
2014/02/12 职场文书
项目负责人任命书
2014/06/04 职场文书
高中学校对照检查材料
2014/08/31 职场文书
负责培养人意见
2015/06/05 职场文书
2015少先队大队辅导员工作总结
2015/07/24 职场文书
python制作图形界面的2048游戏, 基于tkinter
2021/04/06 Python
Html5通过数据流方式播放视频的实现
2021/04/27 HTML / CSS
SpringBoot整合Redis入门之缓存数据的方法
2021/11/17 Redis