首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除主键给出错误,说明它不存在,但不允许我添加,因为它说存在一个

删除主键给出错误,说明它不存在,但不允许我添加,因为它说存在一个
EN

Stack Overflow用户
提问于 2022-10-16 18:19:43
回答 1查看 41关注 0票数 1

我有一个mysql表:

代码语言:javascript
复制
+---------+--------------+------+-----+---------+-------+
| Field   | Type         | Null | Key | Default | Extra |
+---------+--------------+------+-----+---------+-------+
| hash    | varchar(255) | NO   | PRI | NULL    |       |
| user_id | bigint       | NO   | PRI | NULL    |       |
+---------+--------------+------+-----+---------+-------+

但是当运行alter table sessions drop primary key;

代码语言:javascript
复制
ERROR 1091 (42000): target: my-table.-.primary: vttablet: rpc error: code = FailedPrecondition desc = Can't DROP 'PRIMARY'; check that column/key exists (errno 1091) (sqlstate 42000) (CallerID: planetscale-admin): Sql: "alter table sessions drop primary key", BindVars: {}

因此,听起来我似乎清楚地添加了一个主键,如so alter table sessions add primary key (user_id);,但我得到:

代码语言:javascript
复制
ERROR 1062 (23000): target: my-table.-.primary: vttablet: rpc error: code = AlreadyExists desc = Duplicate entry '1' for key 'sessions.PRIMARY' (errno 1062) (sqlstate 23000) (CallerID: planetscale-admin): Sql: "alter table sessions add primary key (user_id)", BindVars: {}

我怎么才能解决这个问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-10-16 19:27:59

我看到打电话的是天平-管理员。所以我猜你在使用PlanetScale Vitess。PlanetScale的要求之一是表必须在任何时候都对非空列具有主键或唯一键。他们使用一个“鬼表”来执行联机表更改,该工具要求原始表和鬼表都有主键(或非空唯一键)。

阅读https://planetscale.com/docs/learn/change-single-unique-key获得关于迁移主密钥的说明,而不违反它们的要求。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74089656

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档