FuelPHP 系列(三)

Stella981
• 阅读 709

框架封装好的 model 类有几个,按需继承就好。

有:/fuel/core/classes/model/crud.php

/fuel/packages/orm/classes/model.php

/fuel/packages/orm/classes/model/soft.php  包含软删除的相关方法

/fuel/packages/orm/classes/model/nestedset.php

/fuel/packages/orm/classes/model/temporal.php

/fuel/core/classes/model.php

/fuel/packages/orm/classes/ 目录下类功能比较多,所以多数情况选择继承这个目录下的 model。

在 /fuel/app/classes/model/ 目录下,可以直接新建,也可以创建一级目录再新建。注意所有的文件名都要小写(Linux)。

一、创建 model 文件

  1、在 model 目录下新建 article.php,文件中 Article 类继承 Orm\Model

  class Model_Article extends Orm\Model{}

  2、在 model/new/ 目录下新建 tag.php,文件中 New 类继承 Orm\Model_Soft

    oil 命令: php oil g model new/tag name:varchar --no-migration   或  php oil g model new_tag name:varchar --no-migration 

  class Model_New_Tag extends Orm\Model_Soft{}

  3、在 model 目录下新建 category.php,文件中 Category 类继承 \Model_Crud

  namespace Model;

  class Category extends \Model_Crud{}

  4、在 model/new/ 目录下新建 test.php,文件中 Test 类继承 Orm\Model_Temporal

  namespace Model\New;

  class Test extends Orm\Model_Temporal{}

  如果定义了 namespace 则在控制器中调用 Model 时,需要在 model 类名前面加命名空间或在文件最上面 use 命名空间下的类名。

  use Model\New\Test;
  class Controller_Article extends \Controller
  {
      public function action_index()
      {
          $test = Test::forge();
        }
  }

二、设置静态属性

  1、设置表名  protected static $_table_name = 'myarticles'; 

    如果数据库表名是 model 类名去掉 ‘Model_’ 后的复数形式,则不要要设置。

  2、设置主键  protected static $_primary_key = array('aid', 'bid'); 

    如果表中主键为 id 且只有 id ,则不需要设置

  3、设置表列  protected static $_properties = array('id', 'name', 'create_at', 'update_at'); 

    也可以设置列属性,数据类型 type、标签 label、验证规则 validation、input 类型 form、默认值 default 等。

  protected static $_properties = array(
        'id',
        'name' => array(
            'data_type' => 'varchar',
            'label' => 'Article Name',
            'validation' => array('required', 'min_length' => array(3), 'max_length' => array(20)),
            'form' => array('type' => 'text'),
            'default' => 'New article',
        ),
        'gender' => array(
            'data_type' => 'varchar',
            'label' => 'Gender',
            'form' => array('type' => 'select', 'options' => array('m' => 'Male', 'f' => 'Female')),
            'validation' => array('required'),
        ),
        'created_at' => array(
            'data_type' => 'int',
            'label' => 'Created At',
            'form' => array(
                'type' => false, // this prevents this field from being rendered on a form
            ),
        ),
        'updated_at' => array('data_type' => 'int', 'label' => 'Updated At')
    );

  4、设置数据约束条件

  protected static $_conditions = array(
    'order_by' => array('id' => 'desc'),
    'where' => array('del_flg', '!=', 1),  
  );

  5、设置关联模型  protected static $_has_one, $_belongs_to, $_has_many, $_many_many 

    一对一、一对多、反向一对多、多对多

  6、设置数据库  protected static $_write_connection = 'articles_master_db'; protected static $_connection = 'articles_slave_db'; 

    在 /fuel/app/config/db.php 文件中配置数据库信息。

    如果数据库设置了主从服务器,实现读写分离,则 $_write_connection 为写数据库,$_connection 为读数据库。

    如果只有一个数据库,则用 $_connection 设置。

    如果有关联模型,则应保证相互关联的模型有相同的读写数据库。

  7、设置隐藏数据  protected static $_to_array_exclude = array( 'password', 'login_hash', 'salt‘, ); 

    返回查询的数据时,忽略敏感信息,比如用户密码、加密规则等。

  8、设置模型事件

  protected static $_observers = array(
        'Orm\Observer_CreatedAt' => array(
            'events' => array('before_insert'),
            'property' => 'INS_DATE',
            'mysql_timestamp' => false,
        ),
        'Orm\Observer_UpdatedAt' => array(
            'events' => array('before_update'),
            'property' => 'UPD_DATE',
            'mysql_timestamp' => false,
        ),
    );

    关于 observer ,后面会有详细介绍。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这