创建函数以从查询中获取数组值的正确方法是什么?我得到"未定义的索引:page_title"错误。 但是我可以获得没有函数的值,如:echo $ row-> page_title; 或echo $ query [0] - > title;
function get_page($id) {
$db = new DB();
$query = $db->get_rows("SELECT * FROM pages WHERE id = :id ", array('id' => $_GET['id']) );
foreach ($query as $row) {
$page_id = $row->id;
$page_title = $row->title;
}
return $query;
}
$page = get_page(1);
echo $page['page_title'];
这是我的数据库类:
function get_rows($query, $values=array(), $fetchType = FETCH_OBJ)
{
$sth = $this->dbh->prepare($query);
if(is_array($values) && (sizeof($values) > 0))
{
foreach($values as $key=>$val)
{
$key = is_numeric($key) ? ($key + 1) : $key;
$sth->bindValue($key,$val);
}
}
if($sth->execute())
return $sth->fetchAll($fetchType);
}
答案 0 :(得分:0)
为了使函数可重用,我将按以下方式重写它
function get_page($id, $col) {
$db = new DB();
$query = $db->prepare('SELECT * FROM pages WHERE id = :id');
$query->execute(array(':id' => $id));
$results = $query->fetch(PDO::FETCH_NUM);
return $results[0][$col];
}
$page = get_page(1, 'page_title');
echo $page;
我跳过了foreach,因为你说所有id都是唯一的,所以你应该只有1个结果
此外,添加一些错误检查可能并不是一个坏主意,以确保您确实获得了对查询的期望,并确保它不是空的。
编辑:对不起,如果语法稍微偏离,没有任何东西可以快速测试代码。