您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

mysql数据库类中出现的问题

2024/8/28 12:24:02发布26次查看
mysql
 这是我的mysql类,继承至db抽象类,其中db的抽象方法在mysql中都以实现,
db类:
abstract class db{
//连接数据库
abstract public function connect($h,$u,$p);
//发送查询
abstract public function query($sql);
//查询多行数据
abstract public function getall($sql);
//查询单行数据
abstract public function getone($sql);
//查询单个数据
abstract public function getrow($sql);
abstract public function autoexecute($arr,$table,$mode='insert ',$where='1 limit 1');
}
class mysql extends db{
private static $ins=null;
private $conn=null;
private $conf=array();
//读取数据库的配置信息
protected function __construct(){
$this->conf=conf::getins();
$this->select_db($this->conf->db);
$this->connect($this->conf->host,$this->conf->user,$this->conf->pwd);//显示是空
$this->setchar($this->conf->char);
}
public function __destruct(){
}
//使用单例模式,只允许new一次
public static function getins(){
if(self::$ins===null){
self::$ins=new self();
}
return self::$ins;
}
//连接,连接失败时,抛出异常
public function connect($h,$u,$p){
//没走到这一步
$this->conn=mysql_connect($h,$u,$p);
}
protected function select_db($db){
$sql='use '.$db;
$this->query($sql);
}
protected function setchar($char){
$sql='set names '.$char;
return $this->query($sql);
}
//发送数据
public function query($sql){
/*if($this->conf->debug){
log::write($sql);
}*/
/* var_dump($sql);
exit;*/
$rs=mysql_query($sql,$this->conn);
/*if(!rs){
log::write($this->error());
}*/
if(!$rs){
echo '失败
';
var_dump($this->conn);
echo '
';
var_dump($this->conf);
}
return $rs;
}
//自动进行计算
 public function autoexecute($arr,$table,$mode='insert ',$where='1 limit 1'){
  if(!is_array($arr)){
  return false;
  }//更新表中的数据
  if($mode=='update'){
  $sql='update '.$table.'set';
  foreach($arr as $k=>$v){
  $sql.=$k.='.$v.',;
  }
  $sql=rtrim($sql,',');
  $sql.=$where;
  return $this->query($sql);
  }
  $sql='insert into '.$table.'('.implode(',',array_keys($arr)).')';
  $sql.='values(\'';
  $sql.=implode(',',array_values($arr));
  $sql.='\')';
  return $this->query($sql);
 }
 //取出表中所有符合条件的多行数据
 public function getall($sql){
  $rs=$this->query($sql);
  $list=array();
  while($row=mysql_fetch_assoc($rs)){
  $list[]=$row;
  }
  return $list;
 }
 //取出符合条件的一行数据
 public function getrow($sql){
  $rs=$this->query($sql);
  return mysql_fetch_assoc($rs);
 }
 //取出一个数据
 public function getone($sql){
  $rs=$this->query($sql);
  $row=mysql_fetch_assoc($rs);
  return $row[0];
 }
 //取出影响的数据
 public function affected_rows(){
  return mysql_affected_rows($this->conn);
 }
 //插入一个id
public function insert_id(){
return mysql_insert_id($this->conn);
}
}
为什么会出现:warning: mysql_query(): supplied argument is not a valid mysql-link resource
排查了很多错误,发现程程序没有走到
public function connect($h,$u,$p){
//没走到这一步
$this->conn=mysql_connect($h,$u,$p);
}
想不出什么原因
回复讨论(解决方案) //读取数据库的配置信息
protected function __construct(){
你把构造函数指定成 保护模式
如何能被执行?
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product