活动记录的使用 ====================== 对于如何使用 yii 的活动记录一般信息请参阅 [指南](https://github.com/yiisoft/yii2/blob/master/docs/guide/active-record.md)。 定义一个 redis 活动记录类,你的记录类需要继承自 [[yii\redis\ActiveRecord]] 并且 至少实现 `attributes()` 方法来定义记录的属性。 一个没有指定默认值,默认为 `id` 的主键可以通过 [[yii\redis\ActiveRecord::primaryKey()]] 定义。 主键是属性中必要的一部分,所以请确保你有一个 `id` 属性定义的, 如果你没有指定自己的主键。 以下是一个 `Customer` 的实例模型: ```php 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 活动记录的一般用法和数据库活动记录非常相似,正如 [指南](https://github.com/yiisoft/yii2/blob/master/docs/guide/active-record.md) 中所描述的。 它支持相同的界面和功能,除了以下限制: - 由于 redis 不支持 SQL 查询,因此查询 API 仅限于以下方法: `where()`,`limit()`,`offset()`,`orderBy()` 和 `indexBy()`。 (orderBy() 尚未实现:[#1305](https://github.com/yiisoft/yii2/issues/1305)) - 由于 redis 中没有表,因此无法通过 `via` 表来定义关系。你只能通过其他记录来定义关系。 另外,也可以定义从 redis 的活动记录到普通的活动记录的关系,反之亦然。 使用实例: ```php $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` 范围) ```