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 相关文章推荐
PHP教程 变量定义
Oct 23 PHP
php 网页播放器用来播放在线视频的代码(自动判断并选择视频文件类型)
Jun 03 PHP
PHP获取http请求的头信息实现步骤
Dec 16 PHP
php获取远程图片体积大小的实例
Nov 12 PHP
windows下PHP_intl.dll正确配置方法(apache2.2+php5.3.5)
Jan 14 PHP
php object转数组示例
Jan 15 PHP
php导出csv数据在浏览器中输出提供下载或保存到文件的示例
Apr 24 PHP
Zend Framework教程之Zend_Db_Table表关联实例详解
Mar 23 PHP
PHP实现的DES加密解密封装类完整实例
Apr 29 PHP
Laravel中使用Queue的最基本操作教程
Dec 27 PHP
对于Laravel 5.5核心架构的深入理解
Feb 22 PHP
Laravel 集成微信用户登录和绑定的实现
Dec 27 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
PHP将MySQL的查询结果转换为数组并用where拼接的示例
2016/05/13 PHP
PHP中的use关键字及文件的加载详解
2016/11/28 PHP
js Select下拉列表框进行多选、移除、交换内容的具体实现方法
2013/08/13 Javascript
Google Maps API地图应用示例分享
2014/10/23 Javascript
JavaScript中SetInterval与setTimeout的用法详解
2015/11/10 Javascript
Jquery promise实现一张一张加载图片
2015/11/13 Javascript
JavaScript动态创建form表单并提交的实现方法
2015/12/10 Javascript
JavaScript中日期函数的相关操作知识
2016/08/03 Javascript
AngularJs expression详解及简单示例
2016/09/01 Javascript
Yarn的安装与使用详细介绍
2016/10/25 Javascript
Bootstrap框架建立树形菜单(Tree)的实例代码
2017/10/30 Javascript
JS 中document.write()的用法和清空的原因浅析
2017/12/04 Javascript
JS小球抛物线轨迹运动的两种实现方法详解
2017/12/20 Javascript
React Native 图片查看组件的方法
2018/03/01 Javascript
webpack4 入门最简单的例子介绍
2018/09/05 Javascript
vue axios数据请求get、post方法及实例详解
2018/09/11 Javascript
vue-cli+axios实现文件上传下载功能(下载接收后台返回文件流)
2019/05/10 Javascript
vue 获取视频时长的实例代码
2019/08/20 Javascript
python 装饰器功能以及函数参数使用介绍
2012/01/27 Python
最基础的Python的socket编程入门教程
2015/04/23 Python
python学习数据结构实例代码
2015/05/11 Python
python ftp 按目录结构上传下载的实现代码
2018/09/12 Python
从pandas一个单元格的字符串中提取字符串方式
2019/12/17 Python
python 如何快速复制序列
2020/09/07 Python
如何使用scrapy中的ItemLoader提取数据
2020/09/30 Python
马来西亚最热门的在线时尚商店:FashionValet
2018/11/11 全球购物
Eclipse面试题
2014/03/22 面试题
大学生求职推荐信
2013/11/27 职场文书
参观监狱心得体会
2014/01/02 职场文书
最新奶茶店创业计划书范文
2014/02/08 职场文书
教师考察材料范文
2014/06/03 职场文书
物理学专业求职信
2014/07/04 职场文书
会计求职信怎么写
2015/03/20 职场文书
小学教师岗位职责
2015/04/02 职场文书
三好学生主要事迹材料
2015/11/03 职场文书
一文搞懂php的垃圾回收机制
2021/06/18 PHP