面向对象MOdel

-----------------------------------config.php---------------------------------------------

创新互联作为成都网站建设公司,专注网站建设公司、网站设计,有关成都企业网站建设方案、改版、费用等问题,行业涉及自上料搅拌车等多个领域,已为上千家企业服务,得到了客户的尊重与认可。

//主机名

define('HOST','localhost');

//用户名

define('USER', 'root');

// 密码

define('PWD', '123456');

//数据库

define('DB','ss21');

//字符集

define('CHARSET','utf8');

--------------------------------index.php--------------------------------------------------

include './config.php';

//echo HOST;exit;

include './Model.class.php';

//实例化对象

$user = new Model('info');

$userlist =  $user->select();

var_dump($userlist);

?>

编号编号编号编号编号
编号编号编号编号编号

-------------------------------Model.class.php---------------------------------------------

//定义一个操作数据库类

class Model{

public $tabName;//存储表名的

public $link;//连接数据的对象

public $limit;//  用于存储要显示条数

public $fields='*';// 用于存储要查询的字段

public $allFields; //缓存数据库字段

public $order;//用来存储排序的内容

public $where;//用来存储where条件

//构造方法里面连接数据库

public function __construct($tabName){

//初始化数据库连接

$this->getConnect();

//将你要操作的数据表存储起来

$this->tabName = $tabName;

//获取数据库字段

$this->getFields();

}

//查询

public function select(){

//5.

$sql="SELECT {$this->fields} FROM {$this->tabName} {$this->where} {$this->order} {$this->limit}";

echo $sql;

return $this->query($sql);

}

//查询一条结果

public function find($id){

//你查询的一条结果sql语句

$sql="SELECT {$this->fields} FROM {$this->tabName} WHERE id={$id}";

//调用发送sql语句函数

return $this->query($sql);

//var_dump($list);

}

//统计总条数

public function count(){

//返回值是字符串

$sql="SELECT COUNT(*)  total FROM {$this->tabName}";

$list = $this->query($sql);

return $list[0]['total'];

}

//增加

//$data['name']='zhansan';

//$data['age']=18;

//$data['sex']=1;

//$data['city']='沈阳';

public function add($data){

var_dump($data);

$key = array_keys($data);

$value = array_values($data);

$keys=join(',',$key);

$values = join("','",$value);

//var_dump($value);

//var_dump($key);exit;

$sql="INSERT INTO {$this->tabName}({$keys}) VALUES('{$values}')";

//echo $sql;exit;

return $this->execute($sql);

}

//删除思路 传递一个参数 这个参数是id值 

public function del($id=''){

//如果你没有传递过来id那么就必须传递where条件

if(empty($id)){

$where = $this->where;

}else{

$where = " WHERE id='{$id}'";

}

if(empty($where)){

return '请你传递一个条件进来';

}

$sql="DELETE FROM {$this->tabName} {$where}";

return $this->execute($sql);

}

//修改

//修改需要传递一个参数 这个参数要是要修改的字段的数组

public function update($arr){

//1.判断$arr 是不是数组

//2.判断你是否使用id作为修改内容还是使用where条件作为修改内容

//3.要将你的键和你的值拼接在一起 形成 name='zhangsan',sex='1',age='19',city='北京',

//4.将多出来的逗号取掉

//5.将得到的字符串防止到sql语句的set后面

$sql="UPDEATE {$this->tabName} SET  WHERE id=";

return $this->execute($sql);

}

//每页显示多少条

public function limit($limit){

$this->limit = ' limit '.$limit;

//echo $this->limit;

return $this;

}

//排除的内容应该怎么写

//order by

public function order($str){

$this->order =" ORDER BY {$str} ";

return $this;

}

//字段过滤  字段筛选  查询数据库内容 删除没有的字段

public function field($fields=array()){

//var_dump($fields);

if(!is_array($fields)){

//保证连贯操作

return $this;

}

//检测数据内容删除没有的字段

$fields = $this->check($fields);

if(empty($fields)){

return $this;

}

$this->fields = join(',',$fields);

//echo $this->fields;

return $this;

}

//where 

//$data['id']=1; id=1

//$data['id']=array('lt','10');

//$data['name']=array('like','张');

public function where($data){

//var_dump($data);exit;

//"where sex =1"

//where字符串拼接

//判断传递过来的必须是一个数组 而且不能为空

if(is_array($data) && !empty($data)){

//接受结果的

$result = array();

//循环传递进来的数组得到里面的键和值

foreach($data as $key=>$value){

//判断值是否为数组

if(is_array($value)){

//var_dump($value);exit;

$type = $value[0];

//判断你是什么样的条件将你所要的条件进行拼接

switch($type){

case 'like':

$result[]="{$key} LIKE '%{$value[1]}%'";

break;

case 'lt':

$result[]="{$key}<'{$value[1]}'";

break;

case 'gt':

$result[]="{$key}>'{$value[1]}'";

break;

case 'in':

$result[]="{$key} in({$value[1]})";

break;

}

}else{

//等于

$result[]="{$key}='{$value}'";

}

}

//echo ' WHERE '.join(' and ',$result);

//var_dump($result);exit;

}

//exit;

//where sex =1 and age >18;

//先把数组打开出来

$where = ' WHERE '.join(' and ',$result);

//echo $where;exit;

//var_dump($data);

//用来存储查询条件

$this->where = $where;

//保证连贯操作

return $this;

}

/****************辅助方法***************************/

//连接数据库的方法

protected function getConnect(){

$this->link=MySQLi_connect(HOST,USER,PWD);

if(mysqli_connect_errno($this->link)){

echo mysqli_connect_error($this->link);exit;

}

mysqli_select_db($this->link,DB);

mysqli_set_charset($this->link,CHARSET);

}

//用于 添加 修改 删除

public function execute($sql){

$result = mysqli_query($this->link,$sql);

if($result && mysqli_affected_rows($this->link)>0){

if(mysqli_insert_id($this->link)){

return mysqli_insert_id($this->link);

}

return true; 

}else{

return false;

}

}

//查询操作

public function query($sql){

$result = mysqli_query($this->link,$sql);

if($result && mysqli_num_rows($result)>0){

while($row = mysqli_fetch_assoc($result)){

$list[]=$row;

}

}

return $list;

}

//获取数据库字段方法

protected function getFields(){

//查看表信息的数据库语句

$sql="DESC {$this->tabName}";

//发送SQL语句

$result = $this->query($sql);

//新建一个数组 用来存储数据库字段

$fields = array();

foreach($result as $value){

//var_dump($value);

$fields[]=$value['Field'];

}

//var_dump($fields);

//设置为缓存字段

$this->allFields = $fields;

}

//检测字段的方法

public function check($arr){

//遍历传递过来的数组  我们才能拿到数组中的键和值

foreach($arr as $key=>$value){

//echo $value.'
';

//判断 你的值是否在缓存字段的数组中allFields

if(!in_array($value,$this->allFields)){

unset($arr[$key]);

}

}

//var_dump($arr);

return $arr;

}

//析构方法

public function __destruct(){

mysqli_close($this->link);

}

}

 





当前题目:面向对象MOdel
本文来源:http://myzitong.com/article/jidhhc.html