使用medoo插件来链接和操做数据库。php
原文连接:http://www.voidking.com/2017/...mysql
一、在composer中添加依赖:git
"catfan/medoo": "*"
二、更新依赖composer update
github
一、config目录添加medoo_config.php为:sql
<?php return array( 'database_type' => 'mysql', 'database_name' => 'vkphp', 'server' => 'localhost', 'username' => 'root', 'password' => '', 'charset' => 'utf8', 'port' => 3306,// 可选参数 'prefix' => 'vk_',// 可选,定义表的前缀 );
二、core目录添加medoo.php为:thinkphp
<?php namespace core; class medoo extends \Medoo\Medoo{ public function __construct(){ $conf = \core\conf::all('medoo_config'); parent::__construct($conf); } }
三、app/ctrl/indexCtrl.php中添加函数:数据库
public function medoo(){ $medoo = new \core\medoo(); dump($medoo); }
访问 http://vkphp.dev/index/medoo ,便可看到medoo的相关信息。api
$ret = $medoo->select('user','*',['username'=>'voidking']); dump($ret);
$data = array( 'username'=>'voidking1', 'password'=>'voidking1' ); $ret = $medoo->insert('user',$data); dump($ret);
由于medoo的版本问题(1.4.5),此时并无打印出这条记录的id,而是PDOStatement object。此时,要想获取记录id,有两个方案:php框架
方案一:从medoo中获取app
dump($medoo->id());
方案二:找到vender/catfan/medoo/src/Medoo.php的第1173行,修改成
$this->exec('INSERT INTO ' . $this->tableQuote($table) . ' (' . implode(', ', $fields) . ') VALUES ' . implode(', ', $stack), $map); return $this->pdo->lastInsertId();
$ret = $medoo->delete('user',['username'=>'voidking2']); dump($ret->rowCount()); // 受影响的行数
$ret = $medoo->update('user',['username'=>'voidking2'],['username'=>'voidking1']); dump($ret->rowCount());
yii框架,对于每一个表,咱们都要建立一个model类,继承ActiveRecord类。好比:
<?php namespace app\models; use yii\db\ActiveRecord; // Project.php class Project extends ActiveRecord { public static function model($className=__CLASS__) { return parent::model($className); } public function getTenProject(){ // 具体实现 } }
在使用的时候,新建一个model对象,调用其中的方法便可:
$project = new Project();
thinkphp框架,对于每一个表,咱们不用建立model类。在使用的时候,直接新建一个默认model对象,传入表名,调用其中的方法便可:
$project = M('project');
固然,thinkphp也能够自定义model类,继承Model类。好比:
<?php // ProjectModel.class.php class ProjectModel extends Model{ public function getTenProject(){ // 具体实现 } }
使用D方法新建自定义model对象,找不到定义类的状况下会调用M方法:
$project = D('project');
yii和thinkphp的两种实现方案,殊途同归,一样都包含了默认model类和自定义model类。
yii中,默认model类为ActiveRecord,若是要自定义model类,继承它便可。
thinkphp中,默认model类为Model,若是要自定义model类,继承它便可。
鉴于yii的实现方式,咱们也来新建一个model基类,其余的model类都继承它。
一、core目录下,新建model.php,内容以下:
<?php namespace core; class model extends \core\medoo{ public $table_name = ''; public function __construct($table_name){ $name_arr = explode('\\',$table_name); $this->table_name = strtolower(end($name_arr)); parent::__construct(); //dump($this->table_name); } public function list_all(){ $ret = $this->select($this->table_name,'*'); return $ret; } public function find_by_id($id){ $ret = $this->select($this->table_name,'*',['id'=>$id]); return $ret; } public function find_by_condition($condition){ $ret = $this->select($this->table_name,'*',$condition); return $ret; } public function add($data){ $ret = $this->insert($this->table_name,$data); return $this->id(); } public function del($condition){ $ret = $this->delete($this->table_name,$condition); return $ret->rowCount(); // 受影响的行数 } public function edit($data,$condition){ $ret = $this->update($this->table_name,$data,$condition); return $ret->rowCount(); } }
二、在app/model目录中新建user.php,内容以下:
<?php namespace app\model; class user extends \core\model{ public function __construct(){ parent::__construct(__CLASS__); } }
三、在app/ctrl/indexCtrl.php中添加函数:
$user = new \app\model\user(); dump($user->list_all()); dump($user->find_by_id(1)); dump($user->find_by_condition(['username'=>'voidking'])); dump($user->add(['username'=>'voidking1','password'=>'voidking1'])); dump($user->edit(['username'=>'voidking2'],['username'=>'voidking1'])); dump($user->del(['username'=>'voidking2']));
访问 http://vkphp.dev/index/model ,能够看到操做结果:
操做完成后,也许会感受数据库表比较乱。这时能够清空表,而且从新从1开始自增id。truncate vk_user;
至此,整个框架已经基本完成。接下来,咱们会开发一个迷你项目,在开发的过程当中,测试并改进咱们的框架。
https://github.com/voidking/v...