php 选择表的语句怎么写,php – 使用PDO语句选择表数据

我有一个PHP脚本,通过mysql_选择数据,但最近我一直在读PDO是要走的路,而且mysql_正在变得折旧.现在我将该脚本转换为PDO.

我的问题是,我没有使用$_POST来选择.我只想选择包含所有数据的整个表,所以我输入以下查询:

$query = $dbh->prepare("SELECT * FROM students");

$query->execute();

$result = $query->fetchall(); // or you can just $result = $query as hakre proposed!

所以就像我使用旧的折旧mysql_版本的脚本一样,我使用echo来回显一个带有数据的表.

echo

"

IDA NumberFirst NameLast NameWhyCommentsSignintime

;

foreach($result as $row)

{

echo "

";

echo "

" . $row['id'] . "";

echo "

" .$row['anum'] . " ";

echo "

" . $row['first'] . "";

echo "

" . $row['last'] . "";

echo "

" . $row['why'] . "";

echo "

" . $row['comments'] . "";

echo "

" . $row['signintime'] . "";

echo "

";

}

echo "

";

echo "

";

现在使用这个,我无法获得单个输出到我的表.

我的问题是我在选择陈述中遗漏了什么?或者我没有取任何行?另外我在init.php所需的另一个名为connect.php的脚本中设置连接设置(在我的所有页面的顶部)

编辑:1

编辑代码,使它现在可以工作,还添加一张图片,以显示其他人应该看起来如何!希望有人可以将它用于某种用途!

解决方法:

你实际上做得太多了:

$query = $dbh->prepare("SELECT * FROM students");

$query->execute();

$result = $dbh->query($query);

问题在于:

$result = $dbh->query($query);

检查http://php.net/pdo.query,参数是一个字符串,实际上是上面已经使用的SQL字符串,而不是PDO :: prepare()调用的结果值.

对于简单的查询,您可以这样做:

$result = $dbh->query("SELECT * FROM students");

或者如果你想准备:

$query = $dbh->prepare("SELECT * FROM students");

$query->execute();

$result = $query;

如果你想在查询中插入变量,那么后者是一些样板文件,这就是你准备它的原因.

下一个问题是foreach行:

foreach($result as $row);

由于分号,你正在立即终止循环;在末尾.删除该分号,以便以下角度括号的代码块成为foreach循环的主体.

标签:php,mysql,select,pdo

来源: https://codeday.me/bug/20191007/1868463.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值