为什么php中sql语句查询数据库输出的全是array?

php代码如下:$res=$mysql->getData("selectsid,name,subname,thumbfromcdb_subjectwherecatid=2... php代码如下:

$res=$mysql->getData("select sid,name,subname,thumb
from cdb_subject where catid=26
order by sid desc
limit 0,5");
整句意图是调取catid为26下的所有sid,name,subname和thumb,组成数组赋值给$res。

这句SQL语句是没问题的,在MyphpAdmin可以顺利输出数据;但放到网页里就是不行。结果输出到txt里显示arrayarrayarrayarrayarray,5个无效的array。

数据库字符集是gbk_chinese_ci的,PHP页面是utf-8的,但应该不是这个原因吧,其他位置输出很正常。
展开
 我来答
jiangxibaiyi
推荐于2017-12-15 · 跟随风去旅行-伤心的歌
jiangxibaiyi
采纳数:3973 获赞数:14411

向TA提问 私信TA
展开全部
本来就是array
但不是无效的array
array是数组,他返回的数据是数组形式的
你要是直接 echo一个数组,那显示的就是array
你改用print_r($res)试试
他就不会是单单array了
追问
其实我不用print_r
,之所以这么做是想看看能否正常输出数据。方法笨了点。。。刚试了,print_r
也打不出来,还是array。
thinkingbullet
2013-11-01 · 超过14用户采纳过TA的回答
知道答主
回答量:61
采纳率:0%
帮助的人:35.3万
展开全部

$res是二维数组,从mysql中取出的数据都会以数组的形式返回的,你可以var_dump($res),想在网页中输出取出的数据需要循环遍历:

<?php foreach($res as $value){
    echo $value['field'];//field为你表中的字段名,比如user表中有name字段,那么field就为name,有几个就写几个,不想显示某个字段就不用写
}
?>
追问
我下面的确是foreach,但循环的结果为空,所以就想看看SQL输出这个地方正不正常,有好的方法吗?var_dump到文本里还是array
追答

在第一行加上

ini_set('display_errors', 1);
error_reporting(E_ALL);

运行一下看是什么错误提示,我估计是你查询数据的时候出错了并且你屏蔽了错误输出.

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
圣鸾OJ
2015-09-10 · TA获得超过1629个赞
知道小有建树答主
回答量:1136
采纳率:96%
帮助的人:111万
展开全部
我通过一个页面让用户提交了12个多选列表,
获取出来就是12个数组,

然后根据这12个数组里的内容进行数据库搜索,

可是发现好像没有办法把这12个数组里的内容一项一项提取出来,然后写sql查询语句。。

比如:

$a = array(a,b,c,d);
$b = array(1,2,3,4);
$c = array(I,II,III,IV);
然后我想select * from 表名 where name=a AND name=b AND name=c AND name=d AND name=1 AND name=2..... AND name=IV

不知道如何可以实现呢?用foreach循环的话,只怕每次都是当前元素的值,这样查出来是每一个当前元素可以搜索到的结果。。。

但是我想查询的是所有数组里所有元素存在的条件下,最后的结果。。

求助各位高人!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友c683669
2017-12-05
知道答主
回答量:1
采纳率:0%
帮助的人:919
展开全部
phhp  阿萨德撒大大
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
王者165
2013-11-01 · TA获得超过138个赞
知道小有建树答主
回答量:256
采纳率:0%
帮助的人:55万
展开全部
你取出来的是数组,可能需要再转换一下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式