zoukankan      html  css  js  c++  java
  • ThinkPHP实现了ActiveRecords模式的ORM模型

    ThinkPHP实现了ActiveRecords模式的ORM模型,采用了非标准的ORM模型:表映射到类,记录映射到对象。最大的特点就是使用方便和便于理解(因为采用了对象化),提供了开发的最佳体验,从而达到敏捷开发的目的。

    大理石平台厂家

    下面我们用AR模式来换一种方式重新完成CURD操作。

    创建数据

    1. $User = M("User"); // 实例化User对象
    2. // 然后直接给数据对象赋值
    3. $User->name = 'ThinkPHP';
    4. $User->email = 'ThinkPHP@gmail.com';
    5. // 把数据对象添加到数据库
    6. $User->add();

    如果使用了create方法创建数据对象的话,仍然可以在创建完成后进行赋值

    1. $User = D("User");
    2. $User->create(); // 创建User数据对象,默认通过表单提交的数据进行创建
    3. // 增加或者更改其中的属性
    4. $User->status = 1;
    5. $User->create_time = time();
    6. // 把数据对象添加到数据库
    7. $User->add();

    查询记录

    AR模式的数据查询比较简单,因为更多情况下面查询条件都是以主键或者某个关键的字段。这种类型的查询,ThinkPHP有着很好的支持。 先举个最简单的例子,假如我们要查询主键为8的某个用户记录,如果按照之前的方式,我们可能会使用下面的方法:

    1. $User = M("User"); // 实例化User对象
    2. // 查找id为8的用户数据
    3. $User->where('id=8')->find();

    用AR模式的话可以直接写成:

    1. $User->find(8);

    如果要根据某个字段查询,例如查询姓名为ThinkPHP的可以用:

    1. $User = M("User"); // 实例化User对象
    2. $User->getByName("ThinkPHP");

    这个作为查询语言来说是最为直观的,如果查询成功,查询的结果直接保存在当前的数据对象中,在进行下一次查询操作之前,我们都可以提取,例如获取查询的结果数据:

    1. echo $User->name;
    2. echo $User->email;

    如果要查询数据集,可以直接使用:

    1. // 查找主键为1、3、8的多个数据
    2. $userList = $User->select('1,3,8');

    更新记录

    在完成查询后,可以直接修改数据对象然后保存到数据库。

    1. $User->find(1); // 查找主键为1的数据
    2. $User->name = 'TOPThink'; // 修改数据对象
    3. $User->save(); // 保存当前数据对象

    上面这种方式仅仅是示例,不代表保存操作之前一定要先查询。因为下面的方式其实是等效的:

    1. $User->id = 1;
    2. $User->name = 'TOPThink'; // 修改数据对象
    3. $User->save(); // 保存当前数据对象

    删除记录

    可以删除当前查询的数据对象

    1. $User->find(2);
    2. $User->delete(); // 删除当前的数据对象

    或者直接根据主键进行删除

    1. $User->delete(8); // 删除主键为8的数据
    2. $User->delete('5,6'); // 删除主键为5、6的多个数据
  • 相关阅读:
    JavaWeb WebBrowserTool KernelEngine
    类模板 C++快速入门45
    动态数组的使用
    动态数组的使用
    鱼C小甲鱼
    栈原理演示
    鱼C小甲鱼
    类模板 C++快速入门45
    delphi实例
    栈原理演示
  • 原文地址:https://www.cnblogs.com/furuihua/p/11810934.html
Copyright © 2011-2022 走看看