이 기사의 예에서는 PHP의 간단한 데이터베이스 작업 클래스를 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.
프로젝트를 개발할 때 데이터베이스는 필수입니다. 하지만 데이터베이스의 SQL 문이 너무 복잡해서 머리가 아플 때가 많습니다. 내가 직접 사용하는 데이터베이스 작업 클래스(모델)를 누구나 사용할 수 있도록 제공합니다. 추가, 삭제, 수정, 쿼리를 지원하고 체인 작업을 지원합니다. 코드는 100줄 미만이며 매우 작고 편리하며 소규모 프로젝트의 빠른 배포에 매우 적합합니다.
/** * * @Authot: summer * * @E-mail: wenghang1228@me.com * * @Data: 2015-02-06 * * @Project: 数据库操作类Model * * @Version:1.0 * * @版权所有:夏天的风————记录夏天对技术的追求与生活的热爱 * * @网址: http://www.xtwind.com **/ class Model{ public $field; public $tabname; public $where; public $order; public $limit; //构造函数,链接数据库,给表赋值 function __construct($tabname){ mysql_connect(HOST,USER,PASSWORD); mysql_select_db(DBNAME); mysql_query("set names utf8"); $this->tabname=$tabname; } //组合字段 function field($field){ $this->$field=$field; return $this; } //组合where条件 function where($where){ $this->where="where ".$where; return $this; } //组合order排序条件 function order($order){ $this->order="order by ".$order; return $this; } //组合limit限制条数 function limit($limit){ $this->limit="limit ".$limit; return $this; } //组合和执行select语句 function select($all=""){ if ($all) { $sql="select {$all} from {$this->tabname} order by id"; }else{ $sql="select {$this->filed} from {$this->tabname} {$this->where} {$this->order} {$this->limit}"; } $rst=mysql_query($sql); while ($row=mysql_fetch_assoc($rst)) { $rows[]=$row; } return $rows; } //组合和执行insert语句 function insert($post){ //数据库插入操作,接收数组 foreach ($post as $key => $value) { $keys[]=$key; $vals[]="'".$valu."'"; } $keyStr=join(",",$keys); $valStr=join(",",$vals); $sql="insert into {$this->tabname}($keystr) values()"; if (mysql_query($sql)) { return mysql_insert_id(); }else{ return false; } } //组合和执行delect语句 function delect(){ $sql="delect from {$this->tabname} {$this->where}"; if (mysql_query($sql)) { return mysql_affected_rows(); }else{ return false; } } //组合和执行updata语句 function update($post){ foreach ($psot as $key => $value) { $sets[]="{$key}='{$val}'"; } $setStr=join(",",$sets); $sql="update {$this->tabname} set {$setStr} {$this->where} "; if (mysql_query($sql)) { return mysql_affected_rows(); }else{ return false; } } //从表中取一行数据 function find(){ if ($this->order) { $sql="select * from {$this->tabname} {$this->order} limit 1"; }else{ $sql="select * from {$this->tabname} order by id limit 1"; } $rst=mysql_query($sql); while ($row=mysql_fetch_assoc($rst)) { $rows[]=$row; } return $rows; } //获取总行数 function total(){ $sql="select count(*) from {$this->tabname}"; $rst=mysql_query($sql); if ($rst) { $row=mysql_fetch_row($rst); return $row[0]; }else{ return false; } } } //Model类对象工厂 function M($tabname){ return new Model($tabname); } define("HOST","localhost"); define("USER", "root"); define("PASSWORD", "123456"); define("DBNAME", "test") $user=new Model("user"); $user->field("id,name")->where("id=3")->order("id desc")->limit("3")->select();
이 글이 PHP 프로그래밍에 종사하는 모든 분들께 도움이 되기를 바랍니다.
PHP 간단한 데이터베이스 조작 예제에 관한 더 많은 기사를 보려면 PHP 중국어 사이트를 주목하세요!