Yii2 + Redis作为数据库

我想使用Yii2和redis作为数据库。

到目前为止,我从这里获得了Yii2的Redis ActiveRecord类。

链接1

链接2

但是,我遇到了问题。为什么该类在REDIS中添加为哈希?

除此之外,我找不到插入数据的模式。我添加了一个用户,它将在user:xxx名称空间下添加一个用户,并在其下添加另一条记录s:user:xxx,依此类推,但是主题都没有我在属性中定义的任何字段!仅包含ID。

我知道键值类型数据库和RDBMS是不同的,并且还知道如何在Redis中实现类似记录的关系,但是我不知道为什么它只会保存ID。

到目前为止,我找不到使用redis ActiveRecords的任何示例。

这里有一个,还不够好。

所以这是我的主要主张:如何在YII2中使用activeRecords和不同的数据类型将数据添加到Redis?

如果ActiveRecords无法实现,那么最佳解决方案是什么?在这种情况下

另一个问题:是否可以改用Model并编写自己的model :: save()方法?以这种速度,最好的数据验证解决方案是什么?

实际上,我想成为一个电报机器人,因此我应该获取消息并在RabitMQ中发送它们,并在一个工作线程中获取数据,执行该过程并将结果保存到Redis,最后通过RabitMQ发送响应给用户。

因此,我需要进行大量验证和课程认证,然后保存,选择,范围和保存,以设置列表以及该列表和该列表。

我想要一个好的方法来制作模型或活动记录,或者是进行验证,保存和检索数据到Redis和Yii2的正确解决方案。

回答:

Redis DB可以声明为 组件或 或 。

当声明为 组件( 使用 yii / redis /

cache)时,可以在该组件内访问它以存储 键/值

对,如下所示。

$cache = Yii::$app->cache;

// try retrieving $data from cache

$data = $cache->get($key);

// store $data in cache so that it can be retrieved next time

$cache->set($key, $data);

// one more example:

$access_token = Yii::$app->security->generateRandomString();

$cache->add(

// key

$access_token,

// data (can also be an array)

[

'id' => Yii::$app->user->identity->id

'name' => Yii::$app->user->identity->name

],

// expires

60*60*3

);

另外,其它成分有可能开始为高速缓存建议喜欢使用它session,如果配置成这样或类似的警予\网络\

UrlManager在默认情况下会尝试缓存生成的URL规则在配置文件中的下定义的所有有效的缓存机制cache组件作为解释在这里。因此,在这种情况下,通常会找到一些不同于您的存储数据。

当像在您提供的链接中一样将Redis声明为 ,这意味着使用yii \ redis \

Connection类,您可以使模型扩展\ yii \ redis \

ActiveRecord类,使其成为Yii中的任何其他ActiveRecord模型。到目前为止,我所知道的唯一区别是您需要手动定义属性,因为没有数据库架构可以解析NoSQL数据库。然后,只需像其他任何ActiveRecord模型一样定义规则,方案,关系,事件…即可:

class Customer extends \yii\redis\ActiveRecord

{

public function attributes()

{

return ['id', 'name', 'address', 'registration_date'];

}

public function rules()

{

return [

['name', 'required'],

['name', 'string', 'min' => 3, 'max' => 12, 'on' => 'register'],

...

];

}

public function attributeLabels() {...}

...

}

所有可用的方法包括save()validate()getErrors(),…可以找到这里,应该像任何其他ActiveRecord类可以使用如图所示的官方指南中。

以上是 Yii2 + Redis作为数据库 的全部内容, 来源链接: utcz.com/qa/407019.html

回到顶部