ActiveRecord活动记录类

一.声明AR类(模型层)

namespaceapp\models;

useyii\db\ActiveRecord;

classCustomer extends ActiveRecord

{

/**

*@return string 返回该AR类关联的数据表名

*/

publicstatic function tableName()

{

return 'customer';

}

}

输出sql:createCommand()->getRawSql();

二.使用AR类进行增删改查(控制器层)

//"id" 和"mail" 是 $customer 对象所关联的数据表的对应字段名

$id    = $customer->id;

$email= $customer->email;

AR提供了两种方法来构建 DB 查询并向 AR 实例里填充数据:

yii\db\ActiveRecord::find()

yii\db\ActiveRecord::findBySql()

1.简单查询方法

Customer::find()->one();    此方法返回一条数据;

Customer::find()->all();    此方法返回所有数据;

Customer::find()->count();    此方法返回记录的数量;

Customer::find()->average();    此方法返回指定列的平均值;

Customer::find()->min();    此方法返回指定列的最小值;

Customer::find()->max();    此方法返回指定列的最大值;

Customer::find()->scalar();    此方法返回值的第一行第一列的查询结果;

Customer::find()->column();    此方法返回查询结果中的第一列的值;

Customer::find()->exists();    此方法返回一个值指示是否包含查询结果的数据行;

Customer::find()->asArray()->one();    以数组形式返回一条数据;

Customer::find()->asArray()->all();    以数组形式返回所有数据;

Customer::find()->where($condition)->asArray()->one();    根据条件以数组形式返回一条数据;

Customer::find()->where($condition)->asArray()->all();    根据条件以数组形式返回所有数据;

Customer::find()->where($condition)->asArray()->orderBy('idDESC')->all();    根据条件以数组形式返回所有数据,并根据ID倒序;

2.findOne()和findAll()

// 查询年龄为30,状态值为1的客户

$customer = Customer::findOne(['age' =>30, 'status' => 1]);

$customer =Customer::find()->where(['age' => 30, 'status' => 1])->one();

// 查询id值为10,11,12的客户

$customers = Customer::findAll([10, 11,12]);

$customers =Customer::find()->where(['id' => [10, 11, 12]])->all();

3.where()条件

$customers = Customer::find()->where($cond)->all();

$cond写法举例:

// SQL: (type = 1) AND (status = 2).

$cond =['type' => 1, 'status' => 2]

// SQL:(id IN (1, 2, 3)) AND (status = 2)

$cond =['id' => [1, 2, 3], 'status' => 2]

//SQL:status IS NULL

$cond = ['status' => null]

[[and]]:将不同的条件组合在一起,用法举例:

//SQL:`id=1 AND id=2`

$cond = ['and', 'id=1', 'id=2']

//SQL:`type=1 AND (id=1 OR id=2)`

$cond = ['and', 'type=1', ['or', 'id=1','id=2']]

[[or]]:

//SQL:`(type IN (7, 8, 9) OR (id IN (1, 2,3)))`

$cond = ['or', ['type' => [7, 8, 9]],['id' => [1, 2, 3]]

[[not]]:

//SQL:`NOT (attribute IS NULL)`

$cond = ['not', ['attribute' => null]]

[[between]]: not between 用法相同

//SQL:`id BETWEEN 1 AND 10`

$cond = ['between', 'id', 1, 10]

[[in]]: not in 用法类似

//SQL:`id IN (1, 2, 3)`

$cond = ['in', 'id', [1, 2, 3]]

//IN条件也适用于多字段

$cond = ['in', ['id', 'name'], [['id' =>1, 'name' => 'foo'], ['id' => 2, 'name' => 'bar']]]

//也适用于内嵌sql语句

$cond = ['in', 'user_id', (newQuery())->select('id')->from('users')->where(['active' => 1])]

[[like]]:

//SQL:`name LIKE '%tester%'`

$cond = ['like', 'name', 'tester']

//SQL:`name LIKE '%test%' AND name LIKE'%sample%'`

$cond = ['like', 'name', ['test','sample']]

//SQL:`name LIKE '%tester'`

$cond = ['like', 'name', '%tester', false]

此外,您可以指定任意运算符如下

//SQL:`id >= 10`

$cond = ['>=', 'id', 10]

//SQL:`id != 10`

$cond = ['!=', 'id', 10]

3.增删改

// 插入新客户的记录

$customer = new Customer();

$customer->name = 'James';

$customer->email = 'james@example.com';

$customer->save();  // 等同于 $customer->insert();

// 更新现有客户记录

$customer = Customer::findOne($id);

$customer->email = 'james@example.com';

$customer->save();  // 等同于 $customer->update();

// 删除已有客户记录

$customer = Customer::findOne($id);

$customer->delete();

// 删除多个年龄大于20,性别为男(Male)的客户记录

Customer::deleteAll('age > :age ANDgender = :gender', [':age' => 20, ':gender' => 'M']);

// 所有客户的age(年龄)字段加1:

Customer::updateAllCounters(['age' =>1]);

4.两表联查

4.两表联查

[[ActiveRecord::hasOne()]]:返回对应关系的单条记录

[[ActiveRecord::hasMany()]]:返回对应关系的多条记录

//客户表Model:CustomerModel

//订单表Model:OrdersModel

//首先要建立表与表之间的关系

//在CustomerModel中添加与订单的关系

模型层:

Class CustomerModel extends\yii\db\ActiveRecord

{

...

public function getOrders()

{

//客户和订单是一对多的关系所以用hasMany

//此处OrdersModel在CustomerModel顶部别忘了加对应的命名空间

//id对应的是OrdersModel的id字段,order_id对应CustomerModel的order_id字段

return $this->hasMany(OrdersModel::className(), ['id'=>'order_id']);

}

}

控制器层:

public function actionIndex{

$customer= Customer::find()->where(['name'=>'zhangsan'])->one();

$orders= $customer->getOrders();

或者

$orders= $customer->orders;   // 魔术方法自动补全getOrders();

//关联查询的多次查询

$customer= Customer::find()->with('order')->all();

foreach($customeras $customer){

$orders = $customer ->orders;

}

}

视图层向控制器层传值

首先在所在的视图层  use yii\helpers\Url;使用

Get方式

其次使用<?= Url::to(['控制器/方法'])?>?参数=值

Active Record 活动记录的更多相关文章

  1. 架构模式数据源模式之:表数据入口(Table Data Gateway)、行数据入口(Row Data Gateway)、活动记录(Active Record)

    一:表数据入口(Table Data Gateway) 表数据入口提供了用于访问单个表或者视图(也包含了联表查询)的所有SQL,通常一个表一个类.其它代码通过它来实现对数据库的交互.基于这个特点,表数 ...

  2. Active Record快速入门指南

    一.概述 Active Record(中文名:活动记录)是一种领域模型模式,特点是一个模型类对应关系型数据库中的一个表,而模型类的一个实例对应表中的一行记录.关系型数据库往往通过外键来表述实体关系,A ...

  3. 架构模式中的Active Record和Data Mapper

    架构模式中的Active Record和Data Mapper 概念 在简单应用中,领域模型是一种和数据库结构一致的简单结构,对应每个数据库表都有一个领域类,在这种情况下,有必要让每个对象负责数据库的 ...

  4. .NET应用架构设计—适当使用活动记录模式代替领域模型模式

    阅读目录: 1.背景介绍 2.简单介绍领域模型模式.活动记录模式 3.活动记录模式的简单示例及要点 4.总结 1.背景介绍 对软件开发方法论有兴趣的博友应该发现最近“领域驱动设计”慢慢的被人发现被人实 ...

  5. Yii的学习(4)--Active Record

    摘自Yii官网:http://www.yiiframework.com/doc/guide/1.1/zh_cn/database.ar 在官网原文的基础上添加了CDbCriteria的详细用法. 虽然 ...

  6. DAL、DAO、ORM、Active Record辨析

    转自:http://blog.csdn.net/suiye/article/details/7824943 模型 Model 模型是MVC中的概念,指的是读取数据和改变数据的操作(业务逻辑).一开始我 ...

  7. Active Record Query Interface 数据查询接口(界面) 看到第8节。

    http://guides.rubyonrails.org/active_record_querying.html ✅How to find records using a variety of me ...

  8. 函数调用堆栈及活动记录 堆栈溢出 stack overflow

    小结: 1.当被调函数返回主调函数时,被调函数的 活动记录-activation record / 堆栈帧-stack frame 被 弹出-popping 程序执行栈-program executi ...

  9. SpringBoot与MybatisPlus整合之活动记录(十五)

    活动记录和正常的CRUD效果是一样的,此处只当一个拓展,了解即可 pom.xml <dependencies> <dependency> <groupId>org. ...

  10. 小书MybatisPlus第5篇-Active Record模式精讲

    本文为一个系列中的第五节,前四节访问如下地址: 小书MybatisPlus第1篇-整合SpringBoot快速开始增删改查 小书MybatisPlus第2篇-条件构造器的应用及总结 小书Mybatis ...

随机推荐

  1. Jmeter检查点

    一.Response Assertion(响应断言) 1. 添加响应断言 对Web请求的响应结果进行验证,Response Assertion配置参数 2. 输入需要匹配的字符串 此处对于访问Baid ...

  2. 【机器学习】搞清楚机器学习的TP、FN、FP、TN,查全率和查准率,PR曲线和ROC曲线的含义与关系

    最近重新学习了一下机器学习的一些基础知识,这里对性能度量涉及到的各种值与图像做一个总结. 西瓜书里的这一部分讲的比较快,这些概念个人感觉非常绕,推敲了半天才搞清楚. 这些概念分别是:TP.FN.FP. ...

  3. 【vue】数据代理

    Object.defineProperty()方法 我们先来看几段代码 常用添加属性的方法,以添加age举例 ,点击查看代码 let person = { name: '张三', sex: '男', ...

  4. Java使用Redis实现分布式锁

    1.概述 此处使用Redis的setNx命令和expire命令和del命令来实现分布式锁. 首先我们要知道, 我们的redis执行命令是队列方式的,并不存在多个命令同时运行,所有命令都是串行的访问.那 ...

  5. Swagger UI教程 API 文档神器 搭配Node使用 web api 接口文档 (转)

    http://www.68idc.cn/help/makewebs/qitaasks/20160621620667.html 两种方案 一.Swagger 配置 web Api 接口文档美化 二.通过 ...

  6. C# DataTable操作,转载

    DataTable 排序   DataRow[] rows = dataTable1.Select("", "ord asc");   DataTable t ...

  7. mysql替换空格制表符换行

    update ztbdb_pro set pro=REPLACE(pro,CHAR(10),''); update ztbdb_pro set pro=REPLACE(pro,CHAR(13),'') ...

  8. virsh虚拟机使用网桥来实现上网

    使用virsh-install安装虚拟机后,虚拟机不可以上网 第一步:主机上配置网桥 cp ifcfg-eno16777736    /tmp/ cp ifcfg-eno16777736  ifcfg ...

  9. vue 数组修改 页面无法刷新

    saveData: { current: 1, records:[] , total:0}, countSaveMoney:{ bidSuccessMoney:0, saveMoney:0},页面上有 ...

  10. [jointjs] 端口(port)

    关于端口,我也不知道怎么解释,就用joint官网的这句话先打个头. Many diagramming applications deal with the idea of elements with ...