PHP用mysqli_fetch_array函数获取一行数据之后无法得到字段的值?打印一下获取到数据结果吧,
比如说打印 var_dump($check_user_temp)吧,不过从你的代码上看,不知是不是你复制粘贴的问题,$check_user_temp[" $check_user"], 这个位置多了空格 , 核对一下吧 。
PHP PDO中fetch的问题query得到$rs后
$rs-setFetchMode(PDO::FETCH_ASSOC); //设置关联模式
然后再$rs-fetchAll
即可得到字段-值的关联形式
PHP 中Fetch,FetchAll从数据库中取数据,遍历出来的都是字符串吗举例php接收fetch数据,首先看了pymysql里面的cursor类php接收fetch数据,关于execute、fetchone和fetchall定义如下php接收fetch数据:
#调用self._query方法进行查询
def execute(self, query, args=None):
"""Execute a query
:param str query: Query to execute.
:param args: parameters used with query. (optional)
:type args: tuple, list or dict
:return: Number of affected rows
:rtype: int
If args is a list or tuple, %s can be used as a placeholder in the query.
If args is a dict, %(name)s can be used as a placeholder in the query.
"""
while self.nextset():
pass
query = self.mogrify(query, args)
result = self._query(query)
self._executed = query
return result
#调用_do_get_result获取查询结果
def _query(self, q):
conn = self._get_db()
self._last_executed = q
self._clear_result()
conn.query(q)
self._do_get_result()
return self.rowcount
#这里获取结果
def _do_get_result(self):
conn = self._get_db()
self._result = result = conn._result
self.rowcount = result.affected_rows
self.description = result.description
self.lastrowid = result.insert_id
self._rows = result.rows
self._warnings_handled = False
if not self._defer_warnings:
self._show_warnings()
其实看到这里代码逻辑已经很清楚了 , 在调用cursor.execute执行SQL的时候,就将MySQL查询的结果放到result这个变量里了,也就是说结果集放到了客户端的内存变量里,那么获取数据的方式也就是从这个内存变量里去获取数据,只是获取的行为有所不同而已了 。
def fetchone(self):
"""Fetch the next row"""
self._check_executed()
if self._rows is None or self.rownumber = len(self._rows):
return None
result = self._rows[self.rownumber]
self.rownumber= 1
return result
def fetchmany(self, size=None):
"""Fetch several rows"""
self._check_executed()
if self._rows is None:
return ()
end = self.rownumber(size or self.arraysize)
result = self._rows[self.rownumber:end]
self.rownumber = min(end, len(self._rows))
return result
def fetchall(self):
"""Fetch all the rows"""
self._check_executed()
if self._rows is None:
return ()
if self.rownumber:
result = self._rows[self.rownumber:]
else:
result = self._rows
self.rownumber = len(self._rows)
return result
口说无凭 , 我们直接通过Wireshark抓包来证明一下,首先我在本地执行脚本如下,然后我监听本地的网卡流量
import pymysql
conn = pymysql.connect(host='xxx', port=3306,
user='xucl', password='xuclxucl', database='xucl')
cursor = conn.cursor()
cursor.execute("select * from t")
注意,我这里并没有执行fetch操作,如果监听到的包里面包含了结果,那么就证明我们前面的分析是正确的,话不多说开始实验,Wireshark抓包如下:
果然跟我们之前的预测是一致的,即使没有进行fetch操作,MySQL也将结果集发送到客户端了 。另外关于结果集发送,可以参考我另外一篇文章:《由一个抓瞎的SQL引申出去》
结论:
客户端执行SQL的时候,MySQL一次性将结果集发送给了客户端
客户端接收到结果集以后存储本地内存变量中
fetch结果只是从这个本地变量中获?。?fetchone/fetchmany/fetchall只是获取行为的不通,因此对于MySQL来说并没有什么不通的 。
php mysql_fetch_array()取数据问题$exec="select * from message limit ".($page*10).",10";
【php接收fetch数据 php接收get请求】echo $exec;//输出这个sql语句,可以在Mysql下运行一下,看是否OK
$result=mysql_query($exec,$conn);
$count=1;
while($rs=mysql_fetch_array($result))
{
print_r($rs);//这里输出看
$count=$count 1;
}
?
li
一般就是三个原因,sql语句出错,连接数据库出错,还有一个,就是取的指定数值出错
你先将sql语句输出看看,然后看看这个while输出是否有问题;之后再联系
如何正确理解PHP获取显示数据库数据函数1、PHP获取显示数据库数据函数之 mysql_result()
mixed mysql_result(resource result_set, int row [,mixed field])
从result_set 的指定row 中获取一个field 的数据. 简单但是效率低.
举例:
$link1 = @mysql_connect("server1",
"webuser", "password")
or die("Could not connect
to mysql server!");
@mysql_select_db("company")
or die("Could not select database!");
$query = "select id, name
from product order by name";
$result = mysql_query($query);
$id = mysql_result($result, 0, "id");
$name = mysql_result($result, 0, "name");
mysql_close();
注意,上述代码只是输出结果集中的第一条数据的字段值,如果要输出所有记录,需要循环处理.
for ($i = 0; $i = mysql_num_rows($result); $i)
{
$id = mysql_result($result, 0, "id");
$name = mysql_result($result, 0, "name");
echo "Product: $name ($id)";
}
注意,如果查询字段名是别名,则mysql_result中就使用别名.
2、PHP获取显示数据库数据函数之mysql_fetch_row()
array mysql_fetch_row(resource result_set)
从result_set中获取整行,把数据放入数组中.
举例(注意和list 的巧妙配合):
$query = "select id,
name from product order by name";
$result = mysql_query($query);
while(list($id, $name)
= mysql_fetch_row($result)) {
echo "Product: $name ($id)";
}
3、PHP获取显示数据库数据函数之mysql_fetch_array()
array mysql_fetch_array(resource result_set [,int result_type])
mysql_fetch_row()的增强版.
将result_set的每一行获取为一个关联数组或/和数值索引数组.
默认获取两种数组,result_type可以设置:
MYSQL_ASSOC:返回关联数组,字段名=字段值
MYSQL_NUM:返回数值索引数组.
MYSQL_BOTH:获取两种数组.因此每个字段可以按索引偏移引用,也可以按字段名引用.
举例:
$query = "select id,
name from product order by name";
$result = mysql_query($query);
while($row = mysql_fetch_array
($result, MYSQL_BOTH)) {
$name = $row['name'];
//或者 $name = $row[1];
$name = $row['id'];
//或者 $name = $row[0];
echo "Product: $name ($id)";
}
4、PHP获取显示数据库数据函数之mysql_fetch_assoc()
array mysql_fetch_assoc(resource result_set)
相当于 mysql_fetch_array($result, MYSQL_ASSOC)
5、PHP获取显示数据库数据函数之mysql_fetch_object()
object mysql_fetch_object(resource result_set)
和mysql_fetch_array()功能一样,不过返回的不是数组,而是一个对象.
举例:
$query = "select id, name
from product order by name";
$result = mysql_query($query);
while($row = mysql_fetch_object
($result)) {
$name = $row-name;
$name = $row-id;
echo "Product: $name ($id)";
}
以上这些函数就是PHP获取显示数据库数据函数的全部总结 。
我用php连接数据库用mysqli_fetch_array( )查询数据库信息,返回值是null,但php连接查询数据库的一般步骤如下:
$con=mysqli_connect("localhost","root","123456","dbname");
$sql="SELECT name FROM web";
$result=mysqli_query($con,$sql);
//mysqli_fetch_array是从 结果集 中取得一行作为数字数组或关联数组
/*你可以先var_dump一下你的结果集var_dump($result);看是否为空 。如果为空就不关mysqli_fetch_array的事了,你要检查的就是sql语句 。*/
$row=mysqli_fetch_array($result);
php接收fetch数据的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于php接收get请求、php接收fetch数据的信息别忘了在本站进行查找喔 。
推荐阅读
- 公司活动直播教程文案,公司活动直播教程文案怎么写
- js行动态加属性,js动态添加表格行
- 升级鸿蒙后照片打不开,升级鸿蒙后照片读不出来
- asp.net服务器时间格式,asp formatdatetime
- go语言代码下载 go语言代码生成器
- 大疆air2s鸿蒙系统手机,大疆 鸿蒙
- 安卓uc浏览器插件,手机uc浏览器插件下载
- 简单游戏开发成本分析,游戏开发的成本构成
- python看自带函数 python内置函数详解