{"id":814,"date":"2024-09-06T12:30:17","date_gmt":"2024-09-06T04:30:17","guid":{"rendered":"https:\/\/thereisno.top\/?p=814"},"modified":"2024-10-22T15:30:56","modified_gmt":"2024-10-22T07:30:56","slug":"mysql%e6%95%b0%e6%8d%ae%e9%80%8f%e8%a7%86%e8%a1%a8%e7%9a%84%e7%a4%ba%e4%be%8b%e5%88%86%e6%9e%90","status":"publish","type":"post","link":"https:\/\/thereisno.top\/?p=814","title":{"rendered":"MySQL\u6570\u636e\u900f\u89c6\u8868\u7684\u793a\u4f8b\u5206\u6790"},"content":{"rendered":"\n<p>\u6211\u6709\u4e00\u5f20\u8fd9\u6837\u7684\u4ea7\u54c1\u96f6\u4ef6\u8868\uff1a<\/p>\n\n\n\n<p>part_id&nbsp;&nbsp;&nbsp;part_type&nbsp;&nbsp;&nbsp;product_id<\/p>\n\n\n\n<!--more-->\n\n\n\n<p>&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8211;<\/p>\n\n\n\n<p>1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;A&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1<\/p>\n\n\n\n<p>2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;B&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1<\/p>\n\n\n\n<p>3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;A&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;2<\/p>\n\n\n\n<p>4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;B&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;2<\/p>\n\n\n\n<p>5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;A&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;3<\/p>\n\n\n\n<p>6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;B&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;3<\/p>\n\n\n\n<p>\u6211\u60f3\u8981\u4e00\u4e2a\u8fd4\u56de\u5982\u4e0b\u8868\u683c\u7684\u67e5\u8be2\uff1a<\/p>\n\n\n\n<p>product_id&nbsp;&nbsp;&nbsp;part_A_id&nbsp;&nbsp;&nbsp;part_B_id<br>&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;-<\/p>\n\n\n\n<p>1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;2<br>2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;4<br>3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;6<\/p>\n\n\n\n<p>\u5728\u5b9e\u9645\u5b9e\u65bd\u4e2d,\u5c06\u6709\u6570\u767e\u4e07\u4e2a\u4ea7\u54c1\u90e8\u4ef6<\/p>\n\n\n\n<p>\u6700\u4f73\u7b54\u6848<\/p>\n\n\n\n<p>\u9057\u61be\u7684\u662f,MySQL\u6ca1\u6709PIVOT\u529f\u80fd,\u4f46\u60a8\u53ef\u4ee5\u4f7f\u7528\u805a\u5408\u51fd\u6570\u548cCASE\u8bed\u53e5\u5bf9\u5176\u8fdb\u884c\u5efa\u6a21.\u5bf9\u4e8e\u52a8\u6001\u7248\u672c,\u60a8\u9700\u8981\u4f7f\u7528\u9884\u51c6\u5907\u8bed\u53e5\uff1a<\/p>\n\n\n\n<p>SET&nbsp;@sql&nbsp;=&nbsp;NULL;<br>SELECT&nbsp;GROUP_CONCAT(DISTINCT&nbsp;&nbsp;CONCAT(<br>&nbsp;&nbsp;&nbsp;&#8216;max(case&nbsp;when&nbsp;part_type&nbsp;=&nbsp;&#8221;&#8217;,part_type,&#8221;&#8217;&nbsp;then&nbsp;part_id&nbsp;end)&nbsp;AS&nbsp;part_&#8217;,&#8217;_id&#8217;&nbsp;&nbsp;)<br>&nbsp;)&nbsp;INTO&nbsp;@sql FROM&nbsp;parts;<br>SET&nbsp;@sql&nbsp;=&nbsp;CONCAT(&#8216;SELECT&nbsp;product_id,&#8217;,@sql,&#8217;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;FROM&nbsp;parts&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;GROUP&nbsp;BY&nbsp;product_id&#8217;);<br>PREPARE&nbsp;stmt&nbsp;FROM&nbsp;@sql;<br>EXECUTE&nbsp;stmt;<br>DEALLOCATE&nbsp;PREPARE&nbsp;stmt;<\/p>\n\n\n\n<p>\u5982\u679c\u60a8\u53ea\u6709\u51e0\u5217,\u90a3\u4e48\u60a8\u53ef\u4ee5\u4f7f\u7528\u9759\u6001\u7248\u672c\uff1a<\/p>\n\n\n\n<p>select&nbsp;product_id,max(case&nbsp;when&nbsp;part_type&nbsp;=&#8217;A&#8217;&nbsp;then&nbsp;part_id&nbsp;end)&nbsp;as&nbsp;Part_A_Id,max(case&nbsp;when&nbsp;part_type&nbsp;=&#8217;B&#8217;&nbsp;then&nbsp;part_id&nbsp;end)&nbsp;as&nbsp;Part_B_Id<br>from&nbsp;parts<br>group&nbsp;by&nbsp;product_id<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6211\u6709\u4e00\u5f20\u8fd9\u6837\u7684\u4ea7\u54c1\u96f6\u4ef6\u8868\uff1a part_id&nbsp;&nbsp;&nbsp;part_type&nbsp;&#038; &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/thereisno.top\/?p=814\" class=\"more-link\">\u7ee7\u7eed\u9605\u8bfb<span class=\"screen-reader-text\">\u201cMySQL\u6570\u636e\u900f\u89c6\u8868\u7684\u793a\u4f8b\u5206\u6790\u201d<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[37],"tags":[68,150],"class_list":["post-814","post","type-post","status-publish","format-standard","hentry","category-mysql","tag-mysql","tag-150"],"_links":{"self":[{"href":"https:\/\/thereisno.top\/index.php?rest_route=\/wp\/v2\/posts\/814","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/thereisno.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/thereisno.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/thereisno.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/thereisno.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=814"}],"version-history":[{"count":2,"href":"https:\/\/thereisno.top\/index.php?rest_route=\/wp\/v2\/posts\/814\/revisions"}],"predecessor-version":[{"id":1308,"href":"https:\/\/thereisno.top\/index.php?rest_route=\/wp\/v2\/posts\/814\/revisions\/1308"}],"wp:attachment":[{"href":"https:\/\/thereisno.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=814"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/thereisno.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=814"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/thereisno.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=814"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}