php动态网站开发第5章答案,从零开始打造自己的PHP框架——第5章

目标

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

medoo基础

安装medoo

1、在composer中添加依赖:

"catfan/medoo": "*"

2、更新依赖

composer update

使用medoo

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

return array(

'database_type' => 'mysql',

'database_name' => 'vkphp',

'server' => 'localhost',

'username' => 'root',

'password' => '',

'charset' => 'utf8',

'port' => 3306,// 可选参数

'prefix' => 'vk_',// 可选,定义表的前缀

);

2、core目录添加medoo.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);

}

620cd188f04e

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类。比如:

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类。比如:

// 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,内容如下:

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,内容如下:

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']));

620cd188f04e

image

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

truncate vk_user;

小结

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

源码分享

书签

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值