从零开始打造自己的PHP框架——第5章

目标

使用medoo插件来连接和操作数据库。

medoo基础

安装medoo

1、在composer中添加依赖:

"catfan/medoo": "*"

2、更新依赖
composer update

使用medoo

1、config目录添加medoo_config.php为:

<?php

return array(
    'database_type' => 'mysql',
    'database_name' => 'vkphp',
    'server' => 'localhost',
    'username' => 'root',
    'password' => '',
    'charset' => 'utf8',
    'port' => 3306,// 可选参数
    'prefix' => 'vk_',// 可选,定义表的前缀
);

2、core目录添加medoo.php为:

<?php
namespace core;

class medoo extends \Medoo\Medoo{
    public function __construct(){
        $conf = \core\conf::all('medoo_config');
        parent::__construct($conf);
    }
}

3、app/ctrl/indexCtrl.php中添加函数:

public function medoo(){
    $medoo = new \core\medoo();
    dump($medoo);
}

访问 http://vkphp.dev/index/medoo ,即可看到medoo的相关信息。

image

增删查改

查找

$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,有两个方案:

方案一:从medoo中获取

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());

medoo进阶

回顾

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类,继承它即可。

model.php

鉴于yii的实现方式,我们也来新建一个model基类,其他的model类都继承它。

1、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();
    }

}

2、在app/model目录中新建user.php,内容如下:

<?php
namespace app\model;
class user extends \core\model{
    public function __construct(){
        parent::__construct(__CLASS__);
    }
}

3、在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 ,可以看到操作结果:

image

操作完成后,也许会感觉数据库表比较乱。这时可以清空表,并且重新从1开始自增id。
truncate vk_user;

小结

至此,整个框架已经基本完成。接下来,我们会开发一个迷你项目,在开发的过程中,测试并改进我们的框架。

源码分享

https://github.com/voidking/vkphp/releases/tag/v1.5.0

书签

从零开始打造自己的PHP框架

Medoo官方文档

Medoo中文文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,907评论 25 707
  • 前言 使用过thinkphp和yii,涉猎过shopnc。市场上已经有了这么多好的框架,为什么还要开发自己的框架?...
    VoidKing阅读 989评论 2 6
  • 爸爸 我们门前的笨槐花又开了 还是两年以前那样芳香 我们从山里把它带回来的时候 它只是个小小的枝丫 如今却已那样的...
    浅笑安然N阅读 176评论 0 1
  • 有所期待 不荒废 把24小时活出高度 尽管八个小时睡眠 睡觉也做与众不同 希冀美梦 充实每天
    东西cx阅读 252评论 0 3
  • 明月已唤归,红日未出门。 昧旦晨兴切,垂怜天涯客。 前路已迷惘,心忧步不停! 何方是归路?劝君无需愁, 东方已将白...
    乐瑶媛阅读 210评论 1 1