数据库查询实例(基础)
来源:互联网 发布:淘宝退货运费差价 编辑:程序博客网 时间:2024/06/06 18:49
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
0 0
- 数据库查询实例(基础)
- 数据库基础--SQL多表连接查询(详细实例)
- sqlalchemy基础—实例学之二 查询数据库
- 查询数据库的实例
- 数据库实例查询
- 查询当前数据库实例
- hibernate 数据库查询 实例
- jdbc查询数据库基础
- 基础数据库查询优化
- mybatis查询数据库基础
- PHP操作数据库查询实例
- spring JdbcTemplate数据库查询实例
- SpringMVC初级数据库查询实例
- 0015数据库查询 方式 查询语句实例
- 查询基础和连接数据库
- 数据库基础:连接查询总结
- Oracle数据库基础(三)--查询
- oracle数据库SQL查询基础
- Learning Deconvolution Network for Semantic Segmentation
- 如何解决WAMP Server Apache与IIS端口冲突问题
- openstack之网络分析2
- PHP如何添加自带的扩展库
- 创业一年失败:100万买来的6点经验
- 数据库查询实例(基础)
- Linux 安装SNMP v3
- String、StringBuffer和StringBuilder的区别
- 通往WinDbg的捷径(二)
- JAVA 入门简单语法
- 生成区间内互不重复的随机数序列
- MySQL数据类型--整数类型
- 杭电2074 叠筐 二维数组
- Android布局优化