database - Yii2 + Redis 作为数据库

标签 database activerecord redis yii2 models

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

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

link1

link2

但是,我遇到了一个问题。为什么这个类在 REDIS 中添加任何东西作为哈希????

在上面我无法找到它插入数据的模式。我添加一个用户,它将在 user:xxx 命名空间下添加一个用户,在 s:user:xxx 下添加另一条记录,依此类推,但没有一个主题有任何字段,我在属性中定义!仅包含 ID。

我知道Key-value类型的数据库和RDBMS是不同的,也知道在Redis中如何实现像记录这样的关系,但我不知道为什么它只保存ID。

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

这里有一个,但还不够好。

所以这是我的主要问题:如何在 YII2 中使用 activeRecords 和不同的数据类型向 redis 添加数据?

如果 ActiveRecords 不可能,那么最好的解决方案是什么?在这种情况下

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

实际上我想制作一个电报机器人,所以我应该获取消息并在 RabitMQ 中发送它们,在 worker 中获取数据,执行处理并将结果保存到 Redis,最后通过 RabitMQ 将响应发送给用户。

所以我需要做很多验证,当然还有身份验证,然后保存、选择和范围,然后保存以设置列表以及这个和那个....

我想要一种制作模型或事件记录的好方法,或者验证、保存和检索数据到 Redis 和 Yii2 的正确解决方案。

最佳答案

Redis DB 可以声明为缓存组件或数据库连接两者

当它被声明为缓存组件时(使用yii/redis/cache ),它可以在该组件内访问以存储键/值as shown here .

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

如果配置为这样做或喜欢 yii\web\UrlManager,其他组件也可能开始使用它来缓存提议,例如 session默认情况下,它将尝试将生成的 URL 规则缓存在配置文件的 cache 组件下定义的任何有效缓存机制中,如 here 所述。 .所以在这种情况下找到一些不是你的存储数据是正常的。

当 Redis 被声明为数据库连接时,就像您提供的链接中那样,这意味着使用 yii\redis\Connection class 你可以让你的模型扩展它的 \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(),...都可以找到here并且应该像任何其他 ActiveRecord 类一样使用 as shown in the official guide .

关于database - Yii2 + Redis 作为数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41592402/

相关文章:

mysql - 如何处理 MySQL 中的大表?

java - 从oracle表加载3000万条记录到内存

database - 我应该如何编写我的连接字符串?

java - JPA持久性问题

ruby-on-rails - 单表继承和 ActiveRecord 关联

Ruby Activerecord IN 子句

c# - 使用 StackExchange.Redis 时出现错误 'WRONGTYPE Operation against a key holding the wrong kind of value'

php - 如何在 Laravel 5 中使用 Redis 为 Multi-Tenancy 多数据库架构应用程序执行排队和缓存?

Redisson本地缓存使用

ruby-on-rails - First_or_create 在比赛中更新?