这篇文章主要介绍了php基于单例模式封装mysql类,结合完整实例形式分析了php使用单例模式封装的mysql类定义与使用方法,需要的朋友可以参考下
具体如下:
类:
<?php
header("content-type:text/html;charset=utf-8");
//封装一个类
/*
掌握满足单例模式的必要条件
(1)私有的构造方法-为了防止在类外使用new关键字实例化对象
(2)私有的成员属性-为了防止在类外引入这个存放对象的属性
(3)私有的克隆方法-为了防止在类外通过clone成生另一个对象
(4)公有的静态方法-为了让用户进行实例化对象的操作
*/
class db{
//三私一共
//私有的静态属性
private static $dbcon=false;
//私有的构造方法
private function __construct(){
$dbcon=@mysql_connect("localhost","root","root");
mysql_select_db("small2",$dbcon) or die("mysql_connect error");
mysql_query("set names utf8");
}
//私有的克隆方法
private function __clone(){}
//公用的静态方法
public static function getintance(){
if(self::$dbcon==false){
self::$dbcon=new self;
}
return self::$dbcon;
}
//打印数据
public function p($arr){
echo "<pre>";
print_r($arr);
echo "</pre>";
}
public function v($arr){
echo "<pre>";
var_dump($arr);
echo "</pre>";
}
//执行语句
public function query($sql){
$query=mysql_query($sql);
return $query;
}
/**
* 查询某个字段
* @param
* @return string or int
*/
public function getone($sql){
$query=$this->query($sql);
return mysql_result($query,0);
}
//获取一行记录,return array 一维数组
public function getrow($sql,$type="assoc"){
$query=$this->query($sql);
if(!in_array($type,array("assoc",'array',"row"))){
die("mysql_query error");
}
$funcname="mysql_fetch_".$type;
return $funcname($query);
}
//获取一条记录,前置条件通过资源获取一条记录
public function getformsource($query,$type="assoc"){
if(!in_array($type,array("assoc","array","row")))
{
die("mysql_query error");
}
$funcname="mysql_fetch_".$type;
return $funcname($query);
}
//获取多条数据,二维数组
public function getall($sql){
$query=$this->query($sql);
$list=array();
while ($r=$this->getformsource($query)) {
$list[]=$r;
}
return $list;
}
//获得最后一条记录id
public function getinsertid(){
return mysql_insert_id();
}
/**
* 定义添加数据的方法
* @param string $table 表名
* @param string orarray $data [数据]
* @return int 最新添加的id
*/
public function insert($table,$data){
//遍历数组,得到每一个字段和字段的值
$key_str='';
$v_str='';
foreach($data as $key=>$v){
if(empty($v)){
die("error");
}
//$key的值是每一个字段s一个字段所对应的值
$key_str.=$key.',';
$v_str.="'$v',";
}
$key_str=trim($key_str,',');
$v_str=trim($v_str,',');
//判断数据是否为空
$sql="insert into $table ($key_str) values ($v_str)";
$this->query($sql);
//返回上一次增加操做产生id值
return mysql_insert_id();
}
/*
* 删除一条数据方法
* @param1 $table, $where=array('id'=>'1') 表名 条件
* @return 受影响的行数
*/
public function deleteone($table, $where){
if(is_array($where)){
foreach ($where as $key => $val) {
$condition = $key.'='.$val;
}
} else {
$condition = $where;
}
$sql = "delete from $table where $condition";
$this->query($sql);
//返回受影响的行数
return mysql_affected_rows();
}
/*
* 删除多条数据方法
* @param1 $table, $where 表名 条件
* @return 受影响的行数
*/
public function deleteall($table, $where){
if(is_array($where)){
foreach ($where as $key => $val) {
if(is_array($val)){
$condition = $key.' in ('.implode(',', $val) .')';
} else {
$condition = $key. '=' .$val;
}
}
} else {
$condition = $where;
}
$sql = "delete from $table where $condition";
$this->query($sql);
//返回受影响的行数
return mysql_affected_rows();
}
/**
* [修改操作description]
* @param [type] $table [表名]
* @param [type] $data [数据]
* @param [type] $where [条件]
* @return [type]
*/
public function update($table,$data,$where){
//遍历数组,得到每一个字段和字段的值
$str='';
foreach($data as $key=>$v){
$str.="$key='$v',";
}
$str=rtrim($str,',');
//修改sql语句
$sql="update $table set $str where $where";
$this->query($sql);
//返回受影响的行数
return mysql_affected_rows();
}
}
?>
测试:
//mysql测试
//$db=db::getintance();
//var_dump($db);
/*$sql="select * from acticle";
$list=$db->getall($sql);
$db->p($list);*/
/*$sql="select * from acticle where acticle_id=95";
$list=$db->getrow($sql);
$db->p($list);
*/
/*$sql="select title from acticle";
$list=$db->getone($sql);
$db->p($list);*/
//$list=$db->insert("users",$_post);
//$del=$db->deleteone("users","id=26");
//$del=$db->deleteall("users","id in(23,24)");
//$up=$db->update("users",$_post,"id=27");
//$id=$db->getinsertid();
//print_r($id);
总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。
相关推荐:
php字符串定义方式及各自区别
php substr函数定义与用法汇总
php表单数据写入mysql数据库的代码
以上就是php基于单例模式封装mysql类的方法的详细内容。