gpt4 book ai didi

mysql - MemSQL - 在表创建中同时将代理键作为主键和不同的唯一键

转载 作者:行者123 更新时间:2023-11-29 02:15:27 24 4
gpt4 key购买 nike

我有一种情况,我需要一个代理键 (id) 来代替复合键(4 个字段组合起来是唯一的:project_id、dataset_id、table_id、view_name) 以便在其他表中轻松引用它。

为此,我使用 id 字段作为主键,并使用上面提到的其他 4 个字段作为唯一键。这在 MySQL 中是允许的,但在 MemSQL 中是不允许的。

Error Code: 1895. The unique key named: 'project_id' must contain all columns specified in the primary key when no shard key is declared

所以我添加了 id 字段作为分片键但没有用。

CREATE TABLE `table_access_details` (
`id` integer primary key,
`project_id` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`dataset_id` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ,
`table_id` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ,
`view_name` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL ,
`upload_id` decimal (14,0) DEFAULT NULL,
`modified_datetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`created_datetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
#SHARD KEY (`id`),
unique(`project_id`,`dataset_id`,`table_id`,`view_name`)
);

如何在 MemSQL 中克服这种情况?

最佳答案

那么,您想要唯一键 (id) 以及唯一键(project_id、dataset_id、table_id、view_name)?这在 memsql 中的分片表中是不可能的 - 无法跨分片有效地强制执行唯一键。您的选择是:不要同时使用这两个唯一键,或者将表设为引用表。

关于mysql - MemSQL - 在表创建中同时将代理键作为主键和不同的唯一键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40520136/

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