Yaf中使用LarvaelEloquentORM

本教程示例代码见:https://github.com/creazy412/yaf_2_eloquent_orm
 

创新互联建站专业为企业提供秀洲网站建设、秀洲做网站、秀洲网站设计、秀洲网站制作等企业网站建设、网页设计与制作、秀洲企业网站模板建站服务,十多年秀洲做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

背景介绍

 
Yaf 是鸟哥(Laruence)在俩年前写的一个PHP扩展的MVC框架. 开发Yaf的目的是为了解决使用框架带来的性能下降的经典矛盾.
 
链接有一篇框架作者本人对 Yaf 框架的理解说明。

 

Yaf框架的一个特点就是轻量,很多东西比如ORM都没有官方提供,而是交由开发者自己选择自己喜欢的ORM或者自己开发一套ORM在框架中使用,而在此次项目中,我使用了Laravel框架的Eloquent ORM,目前Laravel已经将自己的Eloquent ORM进行了组件化,只需要使用composer就可以安装,安装完成后,在Yaf的bootstrap文件中,引入composer的autoload文件即可。
 

基础准备

 
PHP 版本要求 >= 5.4,这是 Eloquent 的最低要求。
这里使用的 phpstudy 集成环境安装包

下载 Yaf 框架,地址是 http://pecl.php.net/package/yaf ,下载完成后按照手册安装即可(http://www.laruence.com/manual/yaf.install.html#yaf.configure),配置好 HTTP 服务软件,把网站跑起来。如果你已经看到了以下画面,就可以继续往下做了:
Yaf 中使用 Larvael Eloquent ORM
 

开始嫁接

 
  我们使用 Composer 来载入和管理 Eloquent。Composer 会生成一个自动加载('autoload')文件,我们只需要 'require' 这个文件,就可以使用所有通过 Composer 安装的包。现在我们要在 CodeIgniter 项目中使用 Composer,在其根目录下新建 composer.json:

{

  "require": {

    "php": ">=5.4.0",

    "illuminate/database": "*"

  }

}

 
然后运行 'composer update',稍等片刻,Composer 体系创建完成,同时 illuminate/database 包也已经安装完成。
 
然后新建 'application/eloquent.php':

addConnection($db['eloquent']);

$capsule->bootEloquent();

 
这个文件将会帮我们引入 Composer 的自动加载文件,同时会帮我们初始化 Eloquent,这个文件载入了一个数据库配置文件,在 'conf/database.php' 的最后新增(注意替换数据库名称和密码):

 'MySQL',

  'host'      => 'localhost',

  'database'  => 'yaf',

  'username'  => 'root',

  'password'  => '123123',

  'charset'   => 'utf8',

  'collation' => 'utf8_general_ci',

  'prefix'    => ''

  ];

 
接下来我们需要在 Yaf 应用启动的时候引入上面那个文件,在入口文件的‘index.php’ 的后部增加:
 

bootstrap() /*实例化Bootstrap, 依次调用Bootstrap中所有_init开头的方法*/
    ->run();

 
然后,开始使用 Eloquent,修改 'application/controllers/Index.php' 中的 'bootstrapAction()' 为:

public function bootstrapAction()
    {
        $result = UserModel::all();

        $this->getView()->assign("result", $result);
    }

 
新建 'application/views/index/bootstrap.phtml' 文件(为了简洁,直接使用bootstrap模版和响应式表格):



  
    
    
    
    
    Bootstrap 101 Template

    
    

    
    
    
  
  
    

    
    
$value) { ?>
# name email operation
delete | edit

 
现在让我们向数据库中填充需要使用的数据,运行 SQL 语句:

DROP TABLE IF EXISTS 'yaf';

CREATE TABLE 'yaf' (

  'id' int(11) unsigned NOT NULL AUTO_INCREMENT,

  'name' varchar(255) NOT NULL DEFAULT '',

  'email' varchar(255) NOT NULL DEFAULT '',

  PRIMARY KEY ('id')

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

LOCK TABLES 'yaf' WRITE;

/*!40000 ALTER TABLE 'yaf' DISABLE KEYS */;

INSERT INTO 'yaf' ('name', 'email')

VALUES

  ('小明', 'xiaoming@qq.com'),

  ('小红', 'xiaohong@qq.com');

/*!40000 ALTER TABLE 'yaf' ENABLE KEYS */;

UNLOCK TABLES;

 
然后建立模型,新建 'application/models/User.php' 文件:
 

 
至此,http://localhost:81/bd/yaf-demo/public/index.php/index/bootstrap 刷新页面即可:
Yaf 中使用 Larvael Eloquent ORM

 
 
 
参考文献:https://lvwenhan.com/php/414.html


新闻名称:Yaf中使用LarvaelEloquentORM
本文路径:http://scjbc.cn/article/piisse.html