切换到PDO后网页内容未显示

时间:2013-06-08 17:26:37

标签: php mysql database pdo

我试图将我的代码从mysql切换到PDO似乎一切正常,因为我没有得到任何错误,但网页的内容没有显示。

这是我的数据库连接结构

try {
        $conn = new PDO('mysql:host=localhost;dbname=***', '***', '***', array(PDO::ATTR_PERSISTENT => true));
        $conn->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    } catch(PDOException $e) {
        echo "Problem with connection ".$e->getMessage();
    }

所以我尝试了一个新页面,其中包含我在我的库中使用PDO的一个功能,并显示

<?php
require_once('functions/generalfunctions.php');
try {
        $conn = new PDO('mysql:host=localhost;dbname=***', '***', '***');
        $conn->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        echo "success";
    } catch(PDOException $e) {
        echo "I'm sorry there is a problem with your operation..";
        file_put_contents( 'dbErrors.txt', $e->getMessage(), FILE_APPEND );
        }

    try{
        $query = $conn->prepare("SELECT * FROM categories ORDER BY title");
        $query->execute();
        $i = 0;
        while($output = $query->fetch()){
            echo '<li><a href="category.php?cat_id='.encrypt_id($output["id"]).'" class="parent" rel="'.$i.'">'.$output["title"].'</a>'. "\n" .'<ul class="child'.$i.'">';
            $stm = "SELECT title,id FROM sections WHERE cat_id=".$output["id"]." ORDER by title";
            $query = $conn->prepare($stm);
            $query->execute();
            while($out = $query->fetch()){
                $stm = "SELECT count(sec_id) AS topic_count FROM topic WHERE sec_id =".$out["id"];
                $qry = $conn->prepare($stm);
                $qry->execute();
                $cnt = $qry->fetch();
                echo "<li>";
                echo '<a href="sections.php?sec_id='.encrypt_id($out["id"]).'&cat_id='.encrypt_id($output["id"]).'">'.$out["title"]."</a><span id=\"cnt_no\" class=\"badge badge-inverse\">".$cnt["topic_count"];
                echo "</span></li>";
            }   
            echo "</ul>\n</li>";
            $i++;
        }
    }catch(Exception $e){
        die(header('location: http://localhost/test'));
    }?>

所以我不知道问题出在哪里。请帮忙

我刚刚发现其中一个主要问题......它说

 Notice: Undefined variable: conn in C:\wamp\www\xxx\functions\xxx.php on line 673

和$ conn是保存PDO连接实例的变量(对象)的名称。

现在可能出现什么问题

1 个答案:

答案 0 :(得分:0)

您的代码所做的是嵌套查询。我看到两个嵌套查询。最后一个$qry是安全的。

基本上,您正在覆盖$query结果集。例如,只需将另一个变量更改为$query2即可。为每个新准备的语句执行此操作,并且$ conn可以重用。