欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2024-02-06 18:19:40
...
为什么我这么做。不行呢?
$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); 解决了