mysql - 使用 mysql 作为 nosql 使用 memcached - 表未更新

标签 mysql memcached nosql

我是在 mysql 中使用 nosql 的新手

我已经安装并启用了 memcahed 接口(interface),然后按照以下步骤操作:

-创建了一个新表“用户”

mysql> CREATE TABLE test.users (
  `user_id` varchar(32) NOT NULL DEFAULT '',
  `first` varchar(100) DEFAULT NULL,
  `last` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB

-将其添加到容器表中。

mysql> INSERT INTO containers 
(name, db_schema, db_table, key_columns,
value_columns, unique_idx_name_on_key)
VALUES ('default', 'test', 'users', 'user_id', 'first|last', 'PRIMARY');

mysql> select * from innodb_memcache.containers;
+---------+-----------+-----------+-------------+---------------+-------+------------+--------------------+------------------------+
| name    | db_schema | db_table  | key_columns | value_columns | flags | cas_column | expire_time_column | unique_idx_name_on_key |
+---------+-----------+-----------+-------------+---------------+-------+------------+--------------------+------------------------+
| aaa     | test      | demo_test | c1          | c2            | c3    | c4         | c5                 | PRIMARY                |
| default | test      | users     | user_id     | first|last    | 0     | NULL       | NULL               | PRIMARY                |
+---------+-----------+-----------+-------------+---------------+-------+------------+--------------------+------------------------+
2 rows in set (0.00 sec)

-使用 telnet 启动界面并运行以下命令将值存储到表中。

set foo 0 0 14
Jarvis|Badgley

-现在 get foo 给出存储的结果

get foo
VALUE foo 0 14
Jarvis|Badgley
END

-但是当我检查 mysql 表时,这些值没有被存储。

mysql> select * from test.users;
Empty set (0.00 sec)

我不知道为什么更新的值没有反射(reflect)在表格中。

请帮忙!

最佳答案

按照您的步骤,我已经能够使其正常工作,但进行了一些修复。

首先,用户表定义错误(列“id”不存在)。应该是:

CREATE TABLE test.users (
  `user_id` varchar(32) NOT NULL DEFAULT '',
  `first` varchar(100) DEFAULT NULL,
  `last` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`user_id`)
) ENGINE=InnoDB

如果您配置此表:

INSERT INTO containers 
(name, db_schema, db_table, key_columns,
value_columns, unique_idx_name_on_key)
VALUES ('default', 'test', 'users', 'user_id', 'first|last', 'PRIMARY');

并使用INSTALL PLUGIN daemon_memcached soname "libmemcached.so";启动引擎,您将在mysql.log文件中发现此错误:

InnoDB_Memcached: column 6 in the entry for config table 'containers' in database 'innodb_memcache' has an invalid NULL value
Failed to initialize instance. Error code: 13

因此,您应该为 flagscasexpiry 定义列,如下所示:

CREATE TABLE test.users (
  `user_id` varchar(32) NOT NULL DEFAULT '',
  `first` varchar(100) DEFAULT NULL,
  `last` varchar(100) DEFAULT NULL,
  flags int,
  cas bigint unsigned,
  expiry int,
  PRIMARY KEY (`user_id`)
) ENGINE=InnoDB;

INSERT INTO innodb_memcache.containers 
(name, db_schema, db_table, key_columns,
value_columns, flags, cas_column, expire_time_column, unique_idx_name_on_key)
VALUES ('default', 'test', 'users', 'user_id', 'first|last', 'flags', 'cas', 'expiry', 'PRIMARY');

然后,当您重新启用该插件时,它将开始工作。

telnet localhost 11222
Trying ::1...
Connected to localhost.
Escape character is '^]'.
set key 0 3600 8
John|Doe
STORED

并查询数据库:

mysql> select * from test.users;
+---------+-------+------+-------+------+------------+
| user_id | first | last | flags | cas  | expiry     |
+---------+-------+------+-------+------+------------+
| key     | John  | Doe  |     0 |   50 | 1495534750 |
+---------+-------+------+-------+------+------------+
1 row in set (0.00 sec)

关于mysql - 使用 mysql 作为 nosql 使用 memcached - 表未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33521387/

相关文章:

MySQL语法错误,下划线

json - : cannot use the part to traverse the element更新时Mongo报错

database - 用于用户聊天的 Cassandra 表设计

mysql - 在查询中多次连接同一个表

mysql - 获取最近插入的主键 slick

php - 如何使用javascript按钮单击更改php的变量而不重新加载页面

symfony1 - 配置 Symfony 以与 Memcached 一起使用

c - Libmemcached 为每个获取和设置请求创建套接字

php - 可以将 memcached 键的生存时间 (TTL) 设置为无限大吗?

azure - 不支持使用 TableBatchOperation 检索多行?