我是在 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
因此,您应该为 flags
、cas
和 expiry
定义列,如下所示:
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/