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 09 PHP
PHP笔记之:日期函数的使用介绍
Apr 24 PHP
PHP中多维数组的foreach遍历示例
Jun 13 PHP
ThinkPHP查询返回简单字段数组的方法
Aug 25 PHP
CodeIgniter错误mysql_connect(): No such file or directory解决方法
Sep 06 PHP
PHP中的socket_read和socket_recv区别详解
Feb 09 PHP
PHP微信开发用Cache 解决数据缓存
Jul 11 PHP
php执行多个存储过程的方法【基于thinkPHP】
Nov 08 PHP
php安装dblib扩展,连接mssql的具体步骤
Mar 02 PHP
PHP实现的分页类定义与用法示例
Jul 05 PHP
Laravel使用消息队列需要注意的一些问题
Dec 13 PHP
PhpStorm的使用教程(本地运行PHP+远程开发+快捷键)
Mar 26 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中计算中文字符串长度、截取中文字符串的函数代码
2011/08/09 PHP
基于curl数据采集之单页面采集函数get_html的使用
2013/04/28 PHP
php获取从html表单传递数组的方法
2015/03/20 PHP
php在数据库抽象层简单使用PDO的方法
2015/11/03 PHP
thinkphp分页集成实例
2017/07/24 PHP
JavaScript 核心参考教程 内置对象
2009/10/13 Javascript
javascript 操作cookies及正确使用cookies的属性
2009/10/15 Javascript
json的前台操作和后台操作实现代码
2012/01/20 Javascript
增强用户体验友好性之jquery easyui window 窗口关闭时的提示
2012/06/22 Javascript
JS文本框追加多个下拉框的值的简单实例
2013/07/12 Javascript
jquery 自定义容器下雨效果可将下雨图标改为其他
2014/04/23 Javascript
js与css实现弹出层覆盖整个页面的方法
2014/12/13 Javascript
NodeJS创建基础应用并应用模板引擎
2016/04/12 NodeJs
Highcharts学习之数据列
2016/08/03 Javascript
浅谈jQuery中hide和fadeOut的区别 show和fadeIn的区别
2016/08/18 Javascript
JS与jQuery实现子窗口获取父窗口元素值的方法
2017/04/17 jQuery
Vue.js实现双向数据绑定方法(表单自动赋值、表单自动取值)
2018/08/27 Javascript
在Python中使用base64模块处理字符编码的教程
2015/04/28 Python
windows及linux环境下永久修改pip镜像源的方法
2016/11/28 Python
Python基于tkinter模块实现的改名小工具示例
2017/07/27 Python
python获取命令行输入参数列表的实例代码
2018/06/23 Python
基于Python开发chrome插件的方法分析
2018/07/07 Python
Python3几个常见问题的处理方法
2019/02/26 Python
解决django后台管理界面添加中文内容乱码问题
2019/11/15 Python
基于python纯函数实现井字棋游戏
2020/05/27 Python
python调用私有属性的方法总结
2020/07/24 Python
python+django+selenium搭建简易自动化测试
2020/08/19 Python
自定义Django_rest_framework_jwt登陆错误返回的解决
2020/10/18 Python
Python暴力破解Mysql数据的示例
2020/11/09 Python
西安当代医院管理研究院笔试题
2015/12/11 面试题
计算机大学生的自我评价
2013/10/15 职场文书
自我鉴定 电子商务专业
2014/01/30 职场文书
城市规划应届生推荐信
2014/09/08 职场文书
我的职业生涯规划:打造自己的运动帝国
2014/09/18 职场文书
2015年度优秀员工推荐信
2015/03/23 职场文书
oracle重置序列从0开始递增1
2022/02/28 Oracle