{"id":3749,"date":"2023-11-02T18:28:53","date_gmt":"2023-11-02T09:28:53","guid":{"rendered":"https:\/\/taitan916.info\/blog\/?p=3749"},"modified":"2023-11-17T18:45:52","modified_gmt":"2023-11-17T09:45:52","slug":"post-3749","status":"publish","type":"post","link":"https:\/\/taitan916.info\/blog\/archives\/3749","title":{"rendered":"ON DUPLICATE KEY UPDATE\u5f8c\u306binsert_id\u3092\u53d6\u5f97\u3059\u308b\u3068\u7d50\u679c\u304c0\u306b\u306a\u308b"},"content":{"rendered":"<p>MySQL\u3067ON DUPLICATE KEY UPDATE\u53e5\u6307\u5b9a\u3057\u3001\u30c7\u30fc\u30bf\u306e\u767b\u9332\u30fb\u66f4\u65b0\u3057\u305f\u5f8c\u306b\u300c$mysqli-&gt;insert_id\u300d\u3067ID\u3092\u53d6\u5f97\u3059\u308b\u3068\u7d50\u679c\u304c0\u306b\u306a\u308b\u3068\u3044\u3046\u30b1\u30fc\u30b9\u304c\u3042\u3063\u305f\u3002\u6bce\u56de\u306a\u308b\u308f\u3051\u3067\u306f\u306a\u304f\u540c\u3058\u30c7\u30fc\u30bf\u3092\u307b\u307c\u540c\u6642\u306b\u767b\u9332\u30fb\u66f4\u65b0\u3057\u305f\u969b\u306b\u767a\u751f\u3057\u3066\u3044\u308b\u3063\u307d\u3044\u3002\u4ee5\u4e0b\u306b\u539f\u56e0\u3068\u5bfe\u5fdc\u7b56\u3092\u30e1\u30e2\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u5185\u5bb9<\/h2>\n<p>\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u7528\u610f\u3057\u305f\u3002id\u306b\u4e3b\u30ad\u30fc\u3092\u8a2d\u5b9a\u3057\u3066\u3044\u308b\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"sql\">+----+-----------+-------+---------------------+---------------------+\r\n| id | name      | point | regist_ymd          | update_ymd          |\r\n+----+-----------+-------+---------------------+---------------------+\r\n|  1 | \u9234\u6728      |   100 | 2023-11-02 18:00:54 | 2023-11-02\u00a018:00:54 |\r\n|  2 | \u5c71\u7530      |    50 | 2023-11-02 18:01:05 | 2023-11-02\u00a018:01:05 |\r\n|  3 | \u4f50\u3005\u6728    |    70 | 2023-11-02 18:01:22 | 2023-11-02\u00a018:01:22 |\r\n+----+-----------+-------+---------------------+---------------------+<\/pre>\n<p>&nbsp;<\/p>\n<h2>\u73fe\u8c61<\/h2>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">$sql = '\r\n    INSERT INTO `test_table` \r\n        (\r\n            `id`,\r\n            `name`, \r\n            `point`, \r\n            `regist_ymd`, \r\n            `update_ymd` \r\n        ) \r\n    VALUES\r\n        (\r\n            2,\r\n            \"\u9234\u6728\",\r\n            1000,\r\n            now(), \r\n            now() \r\n        )\r\n    ON DUPLICATE KEY UPDATE\r\n        `name` = \"\u9234\u6728\u7de8\u96c6\", \r\n        `point` = 2000, \r\n        `update_ymd` = now()\r\n';\r\n\r\n$row = $mysqli-&gt;query($sql);\r\n$id = $mysqli-&gt;insert_id;\r\n\r\nvar_dump($id);\r\n#int(2)\u304c\u51fa\u529b\u3055\u308c\u308b\r\n\r\n$row = $mysqli-&gt;query($sql);\r\n$id = $mysqli-&gt;insert_id;\r\n\r\nvar_dump($id);\r\n#int(0)\u304c\u51fa\u529b\u3055\u308c\u308b<\/pre>\n<p>\u611f\u899a\u7684\u306b\u306f2\u56de\u76ee\u306evar_dump\u30672\u304c\u51fa\u529b\u3055\u308c\u305d\u3046\u306a\u306e\u306b0\u304c\u51fa\u529b\u3055\u308c\u305f\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u539f\u56e0<\/h2>\n<p>\u4ee5\u4e0b\u8a18\u4e8b\u3092\u898b\u305f\u611f\u3058\u30c7\u30fc\u30bf\u306e\u767b\u9332\u30fb\u66f4\u65b0\u304c\u7121\u3044\u5834\u5408\u3001\u3053\u306e\u3088\u3046\u306a\u6319\u52d5\u306b\u306a\u308b\u3063\u307d\u3044\u3002<\/p>\n<p><a href=\"https:\/\/stackoverflow.com\/questions\/25195902\/php-mysqli-insert-id-0-after-insert-or-update-should-i-read-first\" target=\"_blank\" rel=\"noopener\">https:\/\/stackoverflow.com\/questions\/25195902\/php-mysqli-insert-id-0-after-insert-or-update-should-i-read-first<\/a><\/p>\n<p><a href=\"https:\/\/stackoverflow.com\/questions\/35562796\/after-insert-on-duplicate-update-i-got-0-from-mysqli-insert-id\" target=\"_blank\" rel=\"noopener\">https:\/\/stackoverflow.com\/questions\/35562796\/after-insert-on-duplicate-update-i-got-0-from-mysqli-insert-id<\/a><\/p>\n<p>\u4eca\u56de\u306e\u5834\u5408\u30011\u56de\u76ee\u306fupdate_ymd(\u66f4\u65b0\u65e5\u6642)\u304c\u66f4\u65b0\u3055\u308c\u308b\u305f\u3081\u6b63\u5e38\u306b\u52d5\u4f5c\u3059\u308b\u304c\u30012\u56de\u76ee\u306fupdate_ymd\u3082\u5168\u3066\u540c\u3058\u5185\u5bb9\u306e\u305f\u3081\u767a\u751f\u3057\u3066\u3044\u308b\u6a21\u69d8\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u5bfe\u5fdc\u7b56<\/h2>\n<p><a href=\"https:\/\/stackoverflow.com\/questions\/778534\/mysql-on-duplicate-key-last-insert-id\/779252#779252\" target=\"_blank\" rel=\"noopener\">\u3053\u3061\u3089\u306e\u8a18\u4e8b<\/a>\u3092\u898b\u308b\u3068\u4ee5\u4e0b\u306e\u3088\u3046\u306bid\u90e8\u5206\u3092\u66f4\u65b0\u3057\u305f\u3088\u3046\u306b\u898b\u305b\u308b\u5f62\u304c\u826f\u3044\u3089\u3057\u3044\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">$sql = '\r\n    INSERT INTO `insert_id_test` \r\n        (\r\n            `id`,\r\n            `name`, \r\n            `point`, \r\n            `regist_ymd`, \r\n            `update_ymd` \r\n        ) \r\n    VALUES\r\n        (\r\n            2,\r\n            \"\u9234\u6728\",\r\n            1000,\r\n            now(), \r\n            now() \r\n        )\r\n    ON DUPLICATE KEY UPDATE\r\n        `id` = LAST_INSERT_ID(`id`),\r\n        `name` = \"\u9234\u6728\u7de8\u96c6\", \r\n        `point` = 2000, \r\n        `update_ymd` = now()\r\n';<\/pre>\n<p>\u300c`id` = LAST_INSERT_ID(`id`)\u300d\u90e8\u5206\u3092\u8ffd\u8a18\u3059\u308b\u3068\u6b63\u5e38\u306b\u52d5\u4f5c\u3057\u305f\u3002<\/p>\n<p>\u5f8c\u306f\u529b\u696d\u3060\u3051\u3069PHP\u306esleep\u3068\u304b\u3067\u6570\u79d2\u958b\u3051\u3066\u51e6\u7406\u3059\u308c\u3070update_ymd\u304c\u5909\u308f\u308b\u306e\u3067\u6b63\u5e38\u306b\u52d5\u4f5c\u3059\u308b\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u6240\u611f<\/h2>\n<p>ON DUPLICATE KEY UPDATE\u53e5\u306f\u672c\u4ef6\u3068\u306f\u5225\u306b\u30aa\u30fc\u30c8\u30a4\u30f3\u30af\u30ea\u30e1\u30f3\u30c8\u306e\u5024\u304c\u98db\u3093\u3060\u308a\u3082\u3059\u308b\u3057\u5fae\u5999\u306b\u4f7f\u3044\u52dd\u624b\u304c\u60aa\u3044\u306a\u3041\u3068\u601d\u3063\u305f\u3002\u3082\u3046\u3061\u3087\u3063\u3068\u4f7f\u3044\u3069\u3053\u308d\u3092\u8003\u3048\u306a\u3044\u3068\u3044\u3051\u306a\u3055\u305d\u3046\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>MySQL\u3067ON DUPLICATE KEY UPDATE\u53e5\u6307\u5b9a\u3057\u3001\u30c7\u30fc\u30bf\u306e\u767b\u9332 ... <\/p>\n","protected":false},"author":1,"featured_media":1072,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[5,66],"tags":[],"class_list":["post-3749","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-mysql","category-database"],"acf":[],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/3749","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/comments?post=3749"}],"version-history":[{"count":0,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/3749\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/media\/1072"}],"wp:attachment":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/media?parent=3749"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/categories?post=3749"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/tags?post=3749"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}