原文地址

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();

    // 查询客户与他们的订单和订单关联的发货地址(注:orders 与 address都是关联关系)
    CustomerModel::find()->with('orders.address')->all();

    // 查询客户与他们的国家和状态为1的订单
    CustomerModel::find()->with([
        'orders' => function ($query) {
            $query->andWhere('status = 1');
            },
            'country',
    ])->all();

注:with中的orders对应getOrders

常见问题:

1.在查询时加了->select();如下,要加上order_id,即关联的字段(比如:order_id)比如要在select中,否则会报错:undefined index order_id

// 查询客户与他们的订单和国家


    CustomerModel::find()->select('order_id')->with('orders', 'country')->all();