gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 21:52:15 26 4
gpt4 key购买 nike

我是在 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com