首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果存在值,则更新else,插入*和2个非uniques

如果存在值,则更新else,插入*和2个非uniques
EN

Stack Overflow用户
提问于 2014-04-26 14:59:35
回答 2查看 74关注 0票数 2

我已经阅读了其他类似问题的答案,但无法理解如何解决我的问题。

我正在处理的表包含用于"jobs"的元键、元键和id of the "job"重复多次。

表结构:

代码语言:javascript
复制
id | job_id | meta_name | meta_content

id是唯一的,job_id会以不同的meta_namemeta_content值重复3-10次,meta_name只能在每个job_id上存在一次,不应该依赖meta_content,因为它会存储从文本到电子邮件到电话号码的任何东西。

我所有使用ON DUPLICATE KEY UPDATE的尝试都失败了,只是创建了新的行,导致了多个job_id+meta_name组合。

有人能帮助构建查询吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-28 20:08:34

meta_name只能在每个job_id上存在一次

然后,您应该在这两列上创建一个组合的唯一索引。

有了这一点,INSERT … ON DUPLICATE KEY UPDATE将按照预期的方式处理这样的数据组合。

票数 1
EN

Stack Overflow用户

发布于 2014-04-28 20:01:23

您必须将两个唯一的键列与

UNIQUE KEY keyname (job_id,meta_name)

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

https://stackoverflow.com/questions/23312616

复制
相关文章

相似问题

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