php数据库操作Call to a member function Execute() on a non-obje报错

Akuma_lht 软件工程师  2015-12-02 10:23:17
class sqlitedb {
//打开sqlite数据库
function conn($dbname) {
$conn = null;
$path ="/etc/ypm/system.cfg";
if(file_exists($path)){
$dbname = str_replace('../', '', $dbname);
$dbname = str_replace('./', '', $dbname);
require_once('pqmdconfig.php');
$key = "dbpath";//verpath
$dbname = getConfig($key,$path).$dbname;
}
$dbPath = 'sqlite:'.$dbname;
try {
$conn = new PDO($dbPath);
//$conn->beginTransaction();
} catch(PDOException $e) {
echo 'Exception is:'.$e->getMessage();
}
return $conn;
}
以上是数据库的链接和查询操作
include "shm_offset.php";
include "sqlite.php";

$obj= new sqlitedb();

if ( isset($_GET['page'])) {//翻页处理

if($conn=$obj->conn('../ypm.db')){

$sql = "select max(id) as total from data_3sec ";
$total = $obj->query($conn,$sql);
$total = $total['0']['total'];
$now=$_GET['page']?$_GET['page']:1;
if($now >=$total){$now = $total;}
if($now <1){$now = 1;}
$list = $now;

$argv = $_GET['argv'];
$argv = explode("|",$argv);
$num = count($argv)-1;

//$sql = "select data,time from data_3sec order by id desc limit ".$list.",1";
$sql = "select data,time,id from data_3sec order by time desc limit 1 offset ".($list-1);
//因为数据量庞大,无法计算总数(卡死),所以改成ID
//dump($sql);
// exit();

$result = $obj->query($conn,$sql);
$data=$result[0]['data'];

// dump($data);
以上是部分查询代码 Call to a member function Execute() on a non-obje 之前是两个数据库是可以运行的,现在改成了一个数据库之后就报这个错误,代码数据库名字方面也该多来了求助各位高手
...全文
235 点赞 收藏 5
写回复
5 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
Akuma_lht 2015-12-02
引用 3 楼 xuzuning 的回复:
print_r($conn); $sth = $conn->prepare($sql); print_r($sth);
终于知道问题在哪了有个地方数据库名字没改到,真是谢谢了要不是print()还找不到,公司临时给的任务也没学过php
回复
Akuma_lht 2015-12-02
引用 3 楼 xuzuning 的回复:
print_r($conn); $sth = $conn->prepare($sql); print_r($sth);
只显示了$conn的信息竟然是PDO Object ( )这是没实例化成功?
回复
xuzuning 2015-12-02
print_r($conn); $sth = $conn->prepare($sql); print_r($sth);
回复
Akuma_lht 2015-12-02
引用 1 楼 xuzuning 的回复:
错误信息指出 Execute 方法不存在,但在你的代码中并未看到在哪里调用了 Execute
//查询操作 function query($conn,$sql) { $result = array(); include "shm_offset.php"; if(count($m_fUsys_OffSet)<2){ if(strpos($sql,'and')==false && strpos($sql,'line')!==false){ $sql = str_replace('where','',$sql); } $sql = str_replace('line','',$sql); $sql = str_replace('=0','',$sql); $sql = str_replace('= 0','',$sql); } try { $sth = $conn->prepare($sql); $sth->execute(); //获取结果 //var_dump($conn); $result = $sth->fetchAll(); } catch(PDOException $e) { echo 'Exception is:'.$e->getMessage(); } return $result; } 不好意思忘贴了
回复
xuzuning 2015-12-02
错误信息指出 Execute 方法不存在,但在你的代码中并未看到在哪里调用了 Execute
回复
相关推荐
发帖
PHP
创建于2008-08-27

1.9w+

社区成员

“超文本预处理器”,是在服务器端执行的脚本语言,尤其适用于Web开发并可嵌入HTML中。PHP语法利用了C、Java和Perl,该语言的主要目标是允许web开发人员快速编写动态网页。
申请成为版主
帖子事件
创建了帖子
2015-12-02 10:23
社区公告
暂无公告