连接到单独的数据库连接文件'

时间:2014-10-30 21:39:18

标签: php mysql pdo

我有两个php文件。一个PHP文件是我连接到mysql数据库的详细信息

第二个PHP文件在数据库上执行SELECT函数

我的问题是第二个PHP文件似乎没有操作第一个PHP文件。

我刚刚开始使用PDO命令而不是MYSQL命令。当我使用Require('connect_db');功能一切正常。由于我已经转移到PDO命令,它不起作用

我收到错误

 Call to a member function execute () on a non object in................

我的代码如下: -

connect_db文件是(我没有显示密码,用户,数据库的字符串: -

        try
             {
             $mysql_link= new PDO("mysql:host=$servername;dbname=dbname;charset=utf8",$username,$password);
             $mysql_link->setAttribute(PDO::ATTR_EMULATE_PREPARES,false);
             $mysql_link->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
             echo "Connected Success";
             }
             catch(PDOException $e)
             {
             echo $e->getMessage();
             }

我的SELECT文件如下: -

             Require('connect_db.php');          

             $stmt=$mysql_link->prepare("SELECT cif_train_uid,cif_stp_indicator FROM schedule WHERE cif_train_uid=:cif_train_uid");
             $stmt->execute(array(':cif_train_uid'=>$cif_train_uid));
             foreach($stmt->fetchAll(PDO::FETCH_ASSOC) as $row) {
              echo $row['cif_train_uid'];   
              echo $row['cif_stp_indicator'];
             }
             $mysql_link=null;

如果我将所有代码合并到一个文件中,它可以正常工作。 (两个脚本都在同一个文件夹中)。所以它只是Require()函数似乎没有工作,但我不明白为什么。感激不尽的任何帮助

1 个答案:

答案 0 :(得分:0)

我可以看到包含/必需文件导致在将代码放入包含文件时不会发生的问题的唯一原因是包含的文件中没有打开的php标记:

<?php
^^^^^ this...
try
{
   $mysql_link= new PDO("mysql:host=$servername;dbname=dbname;charset=utf8",$username,$password);
   ...