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 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题
  • ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体
  • ¥88 实在没有想法,需要个思路
  • ¥15 MATLAB报错输入参数太多
  • ¥15 python中合并修改日期相同的CSV文件并按照修改日期的名字命名文件
  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入