dongyi9484 2013-03-18 19:18
浏览 49
已采纳

重复密钥更新..数据库密钥?

I have a table (id, name, price, menu_id)

I have a page in which every item's name and price is shown, and the users can edit it.

But when I submit, it creates new rows.

The index is on the primary key. Should it be on something else?

I tried the following:

INSERT INTO gerechten 
SET gerecht_naam = :naam, gerecht_prijs = :prijs, menu_id = :menuid 
ON DUPLICATE KEY 
UPDATE gerecht_naam = :naam, gerecht_prijs = :prijs
  • 写回答

2条回答 默认 最新

  • dongzhan2029 2013-03-18 19:23
    关注

    your query will transform to an update whenever any unique key crashes in your table. Up to you to decide where this key should be placed on. For example, your query could be:

    INSERT INTO `gerechten` (`name`, `price`, `menu_id`) 
    VALUES  (:name, :price, :menuid)
    ON DUPLICATE KEY UPDATE 
        name = :name, 
        price = :price
    

    with a unique index on name AND menu_id for example. (I believe there can be several times the same name as long as it is in a different menu)

    Of course if there are various fields combinations that must be unique this is a problematic situation and maybe you should use a different approach, such as a select ... lock statement to check previous existence of the values being edited.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测