活动记录的使用

对于如何使用 yii 的活动记录一般信息请参阅 指南

定义一个 redis 活动记录类,你的记录类需要继承自 yii\redis\ActiveRecord 并且 至少实现 attributes() 方法来定义记录的属性。 一个没有指定默认值,默认为 id 的主键可以通过 yii\redis\ActiveRecord::primaryKey() 定义。 主键是属性中必要的一部分,所以请确保你有一个 id 属性定义的, 如果你没有指定自己的主键。

以下是一个 Customer 的实例模型:

class Customer extends \yii\redis\ActiveRecord
{
    /**
     * @return array 此记录的属性列表
     */
    public function attributes()
    {
        return ['id', 'name', 'address', 'registration_date'];
    }

    /**
     * @return ActiveQuery 定义一个关联到 Order 的记录(可以在其它数据库中,例如 elasticsearch 或者 sql)
     */
    public function getOrders()
    {
        return $this->hasMany(Order::className(), ['customer_id' => 'id']);
    }

    public static function find()
    {
        return new CustomerQuery(get_called_class());
    }
}

class CustomerQuery extends \yii\redis\ActiveQuery
{
    /**
     * 定义一个修改 `$query` 的范围返回有效(status = 1)的客户。
     */
    public function active()
    {
        return $this->andWhere(['status' => 1]);
    }
}

redis 活动记录的一般用法和数据库活动记录非常相似,正如 指南 中所描述的。 它支持相同的界面和功能,除了以下限制:

  • 由于 redis 不支持 SQL 查询,因此查询 API 仅限于以下方法: where()limit()offset()orderBy()indexBy()。 (orderBy() 尚未实现:#1305)
  • 由于 redis 中没有表,因此无法通过 via 表来定义关系。你只能通过其他记录来定义关系。

另外,也可以定义从 redis 的活动记录到普通的活动记录的关系,反之亦然。

使用实例:

$customer = new Customer();
$customer->attributes = ['name' => 'test'];
$customer->save();
echo $customer->id; // 如果没有明确设置 id 会自动递增

$customer = Customer::find()->where(['name' => 'test'])->one(); // 通过 query 查找
$customer = Customer::find()->active()->all(); // 通过 query 查找全部(使用 `active` 范围)