首頁 > 後端開發 > php教程 > 关于PHP实例化对像,在线等 急

关于PHP实例化对像,在线等 急

WBOY
發布: 2016-06-23 13:43:44
原創
835 人瀏覽過

为什么我这么做。不行呢?
$db=new db;
class db
{ function sql($sql){
global $conn;  //数据库
$query = $conn->query($sql);
$rs = mysql_fetch_array($query);
return $rs;
mysql_free_result($query);

}


function Listname(){
$id =Cut(intval($weburl[2]));
$rs = $db->sql("select title from `column` where id = ".$id); 
return $rs[0];
}

报错:
Notice: Undefined variable: db in 
Fatal error: Call to a member function sql() on a non-object in 

14行出错 第14行:$rs = $db->sql("select title from `column` where id = ".$id); 


回复讨论(解决方案)

$db=new db;这句话是不是应该放在创建类下面

$query = $conn->query($sql);
改成
$query =mysql_query($sql,$conn);

把$db=new db;放在function Listname()里面

$db=new db;
这行放到 Listname函数里面去,或者说在Listname函数中调用到$db之前用global把$db全局化。
你既然在sql函数中使用了global关键字全局化了$conn变量,说明你是知道作用域的,怎么还会犯这样的错误

$query = $conn->query($sql);
改成
$query =mysql_query($sql,$conn);



按您所说改成这样:
class db
{ function sql($sql){
global $conn; 
$query = $mysql_query($sql);
$rs = mysql_fetch_array($query);
return $rs;
mysql_free_result($query);

}
$db=new db;

function Listname(){
global $db; 
$id = ourphp_Cut(intval($weburl[2]));
$rs = $db->sql("select title from `column` where id = ".$id); 
return $rs[0];
}
可还是不行
报错:Notice: Undefined variable: mysql_query
Fatal error: Function name must be a string in 

$db=new db;
这行放到 Listname函数里面去,或者说在Listname函数中调用到$db之前用global把$db全局化。
你既然在sql函数中使用了global关键字全局化了$conn变量,说明你是知道作用域的,怎么还会犯这样的错误



按照您所说的 报错Fatal error: Call to a member function query() on a non-object 

我把query()改成mysql_query就报Fatal error: Call to a member function mysql_query() on a non-object in 

这是什么意思呢

谢谢各位 解决把
$query = mysql_query($sql); 解决了

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板