【发布时间】:2015-08-27 14:01:51
【问题描述】:
我正在查询我的数据库,并想编写一个 foreach 循环,通过我的结果集,并在时间戳上运行 strtotime,以便在我的网页上使用它(我想调整数组 [ "posted"] 值到 strtotime(array["posted"])。
我是 php 和 PDO 的新手,不知道我的 foreach 循环出了什么问题。我得到的警告是 Warning: Invalid argument supplied for foreach() in /home/shooshte/Dropbox/PTC_php/db_queries/articles.php on line 29 。
我想我的目标 $result 数组错误?谁能解释如何解决这个问题?时间戳在名为posted 的列中,这也是我数组中的键。
感谢您的帮助。
我的 php:
<?php
error_reporting(E_ALL);
ini_set('display_errors', 1);
try {
$hostname = "localhost";
$username = "root";
$password = "";
$db = new PDO("mysql:host=$hostname;dbname=topdecka_PTC",$username, $password);
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
if (!empty($_POST["searchword"])) {
$searchword = $_POST["searchword"];
$query = $db->prepare("SELECT title, posted, author_id, extract FROM articles WHERE title LIKE :searchword OR extract LIKE :searchword OR body LIKE :searchword");
$query->execute(array(":searchword" => "%" . $searchword . "%"));
$result = $query->fetchAll();
echo json_encode($result);
die();
}
else {
$query = $db->prepare('SELECT posted FROM articles');
$query->execute();
$result = $query->fetchAll();
foreach($result as $row) {
$row['posted'] = strtotime($row['posted']);
}
echo '<pre>';
var_dump($result);
echo '</pre>';
//echo json_encode($result);
die();
}
}
catch (PDOException $e) {
echo "Error!: " . $e->getMessage() . "<br/>";
die();
}
?>
这是var_dump:
array(2) {
[0]=>
array(2) {
["posted"]=>
string(19) "2015-06-10 11:16:46"
[0]=>
string(19) "2015-06-10 11:16:46"
}
[1]=>
array(2) {
["posted"]=>
string(19) "2015-06-10 13:26:54"
[0]=>
string(19) "2015-06-10 13:26:54"
}
}
【问题讨论】:
-
var_dump($result);显示什么? -
@honerlawd 将 var_dump 添加到帖子中