php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别
程序员文章站
2022-09-10 17:45:55
方法名:mssql_fetch_row() 测试: 复制代码 代码如下: require 'dbconn.php'; $sql = 'select * from _test...
方法名: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类似,只有一点区别,即返回一个对象而不是数组,并将字段名字做为属性。间接地也意味着只能通过字段名来访问,而不是偏移量。
测试:
复制代码 代码如下:
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调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和m_PHP教程
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别_php技巧
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和m
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和m
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别_php技巧
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别
-
php的mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc及mssql_fetch_objcect读取数据的
-
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和m_PHP教程