Yii2.0数据库查询应用实例(一)
来源:互联网 发布:手机wifi中继软件 编辑:程序博客网 时间:2024/05/21 14:43
1.简单查询:
[[one()]]: 根据查询结果返回查询的第一条记录。 [[all()]]: 根据查询结果返回所有记录。
[[count()]]: 返回记录的数量。
[[sum()]]: 返回指定列的总数。
[[average()]]: 返回指定列的平均值。
[[min()]]: 返回指定列的最小值。
[[max()]]: 返回指定列的最大值。
[[scalar()]]: 返回查询结果的第一行中的第一列的值。
[[column()]]: 返回查询结果中的第一列的值。
[[exists()]]: 返回一个值,该值指示查询结果是否有数据。
[[where()]]: 添加查询条件
[[with()]]: 该查询应执行的关系列表。
[[indexBy()]]: 根据索引的列的名称查询结果。
[[asArray()]]: 以数组的形式返回每条记录。
应用实例:
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('id DESC')->all(); 根据条件以数组形式返回所有数据,并根据ID倒序;
2.关联查询:
[[ActiveRecord::hasOne()]]:返回对应关系的单条记录
[[ActiveRecord::hasMany()]]:返回对应关系的多条记录
应用实例:
//客户表Model:CustomerModel
//订单表Model:OrdersModel
//国家表Model:CountrysModel
//首先要建立表与表之间的关系 //在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 getCountry() {
//客户和国家是一对一的关系所以用hasOne
return $this->hasOne(CountrysModel::className(), ['id'=>'Country_id']);
}
....}
// 查询客户与他们的订单和国家CustomerModel::find()->with('orders', 'country')->all();
// 查询客户与他们的订单和订单的发货地址CustomerModel::find()->with('orders.address')->all();
// 查询客户与他们的国家和状态为1的订单CustomerModel::find()->with([ 'orders' => function ($query) { $query->andWhere('status = 1'); }, 'country',])->all();
注:with中的orders对应getOrders
1 0
- Yii2.0数据库查询应用实例(一)
- Yii2.0 数据库查询
- Yii2.0 数据库查询
- Yii2.0 数据库查询
- Yii2.0 数据库查询
- Yii2.0 数据库查询
- Yii2.0对数据库 查询
- yii2.0 数据库关联查询
- Yii2.0-数据库事务应用
- YII2.0 查询生成器-数据库访问
- yii2 数据库查询笔记
- yii2中数据库查询
- yii2数据库查询操作
- yii2 数据库查询
- Yii2.0使用AR联表查询实例
- Yii2.0-advanced-10—数据库操作4(AR条件查询where)
- Yii2.0-advanced-10—数据库操作2(查询构建器)
- Yii2.0 对数据库 查询的一些简单的操作
- ORID日志模板
- android 手把手教你写数据库框架(第一篇)
- 基于redis的缓存机制的思考和优化
- Kurento应用开发指南(以Kurento 5.0为模板) 之四:示例教程 一对一视频呼叫
- go语言中的iota
- Yii2.0数据库查询应用实例(一)
- 两个时间戳相减得到分钟数()
- 给zabbix更换nagios图标
- java多线程学习-java.util.concurrent详解(二)Semaphore/FutureTask/Exchanger
- java获取类类型的方法
- B/S架构的网站如何测试
- 定期处理日志限制日志行数
- NB-IoT模块
- androidstudio/IDEA文件类型图标