{"id":4970,"date":"2016-06-23T13:53:10","date_gmt":"2016-06-23T10:53:10","guid":{"rendered":"http:\/\/skeletor.org.ua\/?p=4970"},"modified":"2016-09-21T10:19:31","modified_gmt":"2016-09-21T07:19:31","slug":"mysql-5-7-%d0%b8-optimizer_switch","status":"publish","type":"post","link":"https:\/\/skeletor.org.ua\/?p=4970","title":{"rendered":"[mysql] 5.7 \u0438 optimizer_switch"},"content":{"rendered":"<p>\u0414\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u0440\u0435\u0448\u0438\u043b \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441 <strong>5.6<\/strong> \u043d\u0430 <strong>5.7<\/strong> \u0436\u0434\u0443\u0442 &#8220;\u0441\u044e\u0440\u043f\u0440\u0438\u0437\u044b&#8221; \u0432 \u0432\u0438\u0434\u0435 \u043f\u0435\u0440\u0435\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u043e\u0433\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440\u0430 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440? \u042d\u0442\u043e &#8220;\u043f\u043e\u043c\u043e\u0449\u043d\u0438\u043a&#8221;, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0435\u0440\u0435\u0434 \u043a\u0430\u0436\u0434\u044b\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0449\u0435\u0442 \u043f\u0443\u0442\u044c &#8220;\u043d\u0430\u0438\u043b\u0443\u0447\u0448\u0435\u0433\u043e&#8221; \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u0430. \u0412\u0441\u0435 \u0435\u0441\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0435 10-\u043a\u0430 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c\/\u0432\u044b\u043a\u043b\u044e\u0447\u0430\u0442\u044c, \u0442\u0435\u043c \u0441\u0430\u043c\u044b\u043c \u043c\u0435\u043d\u044f\u044f \u043b\u043e\u0433\u0438\u043a\u0443 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e \u043d\u0438\u0445 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0447\u0435\u0441\u0442\u044c <a href=\"https:\/\/dev.mysql.com\/doc\/refman\/5.7\/en\/switchable-optimizations.html\" target=\"_blank\">\u0437\u0434\u0435\u0441\u044c<\/a>.<\/p>\n<p><!--more--><\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e\u0433\u043e \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0411\u0414 \u0441 <strong>5.6<\/strong> \u043d\u0430 <strong>5.7<\/strong> \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0441\u044f \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043d\u0430 <strong>5.7<\/strong> \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0432 100 \u0440\u0430\u0437 \u0434\u043e\u043b\u044c\u0448\u0435.\u00a0\u0414\u0430\u043b\u044c\u0448\u0435 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441\u0430\u043c\u043e\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435: \u043f\u043e\u0438\u0441\u043a \u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b. \u0412 \u043f\u0435\u0440\u0432\u0443\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u043b\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430 \u0431\u0430\u0437\u0430\u0445 (\u0431\u044b\u043b\u0430 \u0440\u0435\u043f\u043b\u0438\u043a\u0430 \u0431\u0430\u0437\u044b \u0441 <strong>5.6<\/strong>), \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u043b\u0438 <strong>force upgrade<\/strong> \u043d\u0430 <strong>5.7<\/strong> \u0435\u0449\u0451 \u0440\u0430\u0437, \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u043d\u0435 \u0432\u044b\u044f\u0432\u0438\u043b\u0438. \u041f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u00a0explain&#8217;\u043e\u0432 \u0442\u043e\u0436\u0435 \u043d\u0438 \u043a \u0447\u0435\u043c\u0443 \u043d\u0435 \u043f\u0440\u0438\u0432\u0451\u043b (\u043e\u043d\u0438 \u0440\u0430\u0437\u043d\u044b\u0435, \u043d\u043e \u0432\u0435\u0437\u0434\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0438\u043d\u0434\u0435\u043a\u0441\u044b). \u0411\u044b\u043b \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u043f\u0435\u0440\u0435\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0437\u0430\u043d\u043e\u0432\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0432\u0434\u0440\u0443\u0433 \u043f\u043e\u0431\u0438\u043b\u0438\u0441\u044c \u043f\u043e\u0441\u043b\u0435 \u0430\u043f\u0434\u0435\u0439\u0442\u0430, \u043d\u043e \u0431\u0430\u0437\u0430 \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0438 \u0440\u0435\u0448\u0438\u043b\u0438 \u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0441\u0430\u043c\u044b\u0439 \u043a\u0440\u0430\u0439\u043d\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439.<\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e\u0433\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u043b\u0438 \u0432 <strong>processlist<\/strong> \u0438 \u0443\u0432\u0438\u0434\u0435\u043b\u0438 \u0435\u0433\u043e \u0432 \u0441\u0442\u0430\u0442\u0443\u0441\u0435\u00a0<strong>optimizing<\/strong> \u0438 \u044d\u0442\u043e \u043d\u0430\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u043e \u043d\u0430\u0441 \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u044c \u0444\u043b\u0430\u0433\u0438 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u043d\u0430 <strong>5.6<\/strong> \u0438 <strong>5.7<\/strong>. \u0418 <strong>Bingo<\/strong>! \u0412 <strong>5.7<\/strong> \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u043e\u0441\u044c \u0447\u0430\u0441\u0442\u044c \u0444\u043b\u0430\u0433\u043e\u0432, \u0432 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0434\u043b\u044f \u0432\u0435\u0440\u0441\u0438\u0438 <strong>5.7.12<\/strong> \u0431\u044b\u043b\u0438 \u043d\u043e\u0432\u044b\u043c\u0438 \u0442\u0430\u043a\u0438\u0435:<\/p>\n<p><code>duplicateweedout, condition_fanout_filter, derived_merge<\/code><\/p>\n<p>\u0412\u0441\u0435 \u043e\u043d\u0438 \u0431\u044b\u043b\u0438 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u044b \u0432 on \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u041c\u0435\u0442\u043e\u0434\u043e\u043c \u0442\u044b\u043a\u0430 \u0432\u0438\u043d\u043e\u0432\u043d\u0438\u043a\u043e\u043c \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f\u00a0<strong>derived_merge<\/strong>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u0445\u0438\u0442\u0440\u0443\u044e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044e \u0434\u043b\u044f <strong>derived<\/strong> \u0442\u0430\u0431\u043b\u0438\u0446 (\u0442\u043e \u0435\u0441\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0441 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u043c\u0438 &#8211; <strong>select &#8230; from &#8230; (select &#8230; from&#8230;)<\/strong>). \u0418 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e, \u0432 \u043d\u0430\u0448\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0431\u044b\u043b\u043e \u043c\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432.\u00a0<a href=\"http:\/\/dev.mysql.com\/doc\/refman\/5.7\/en\/server-system-variables.html#sysvar_optimizer_switch\" target=\"_blank\">\u0421\u043f\u0438\u0441\u043e\u043a<\/a> \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u044f \u0438\u0445 \u043e\u0442 \u0432\u0435\u0440\u0441\u0438\u0438 \u043a \u0432\u0435\u0440\u0441\u0438\u0438.<\/p>\n<p>\u041e\u0441\u0442\u0430\u0432\u043b\u044e \u0431\u0435\u0437 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0430, \u0447\u0442\u043e \u0431\u044b \u043d\u0435 \u0442\u0435\u0440\u044f\u043b\u0441\u044f \u0441\u043c\u044b\u0441\u043b:<\/p>\n<blockquote><p><span style=\"color: #993366;\">The derived_merge flag controls whether the optimizer attempts to merge derived tables and view references into the outer query block, assuming that no other rule prevents merging. By default, the flag is on to enable merging. Setting the flag to off prevents merging and avoids the error just described. (Other workarounds include using SELECT DISTINCT or LIMIT in the subquery, although these are not as explicit in their effect on materialization.) If an ER_UPDATE_TABLE_USED error occurs for a view reference that uses an expression equivalent to the subquery, adding ALGORITHM=TEMPTABLE to the view definition prevents merging and takes precedence over the current derived_merge value.<\/span><\/p><\/blockquote>\n<p>\u0422\u0430\u043a \u0436\u0435 \u0441\u043e\u0432\u0435\u0442\u0443\u044e \u043f\u0440\u043e\u0447\u0435\u0441\u0442\u044c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u043e\u043b\u043d\u044b\u0439 \u043e\u0431\u0437\u043e\u0440 \u043f\u0440\u043e <strong>derive<\/strong> \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0447\u0435\u0441\u0442\u044c <a href=\"http:\/\/mysqlserverteam.com\/derived-tables-in-mysql-5-7\/\" target=\"_blank\">\u0437\u0434\u0435\u0441\u044c<\/a>.<\/p>\n<p>\u0410 <a href=\"https:\/\/www.percona.com\/blog\/2016\/09\/14\/mysql-default-configuration-changes-between-5-6-and-5-7\/\">\u0437\u0434\u0435\u0441\u044c<\/a> \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043a\u0440\u0430\u0441\u0438\u0432\u043e \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u043d\u043e \u043e\u0431 \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0445 \u043e\u0442\u043b\u0438\u0447\u0438\u044f\u0445\u00a05.6 \u0438 5.7<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0414\u043b\u044f \u0442\u0435\u0445, \u043a\u0442\u043e \u0440\u0435\u0448\u0438\u043b \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441 5.6 \u043d\u0430 5.7 \u0436\u0434\u0443\u0442 &#8220;\u0441\u044e\u0440\u043f\u0440\u0438\u0437\u044b&#8221; \u0432 \u0432\u0438\u0434\u0435 \u043f\u0435\u0440\u0435\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u043e\u0433\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440\u0430 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440? \u042d\u0442\u043e &#8220;\u043f\u043e\u043c\u043e\u0449\u043d\u0438\u043a&#8221;, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0435\u0440\u0435\u0434 \u043a\u0430\u0436\u0434\u044b\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0449\u0435\u0442 \u043f\u0443\u0442\u044c &#8220;\u043d\u0430\u0438\u043b\u0443\u0447\u0448\u0435\u0433\u043e&#8221; \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u0430. \u0412\u0441\u0435 \u0435\u0441\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0435 10-\u043a\u0430 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c\/\u0432\u044b\u043a\u043b\u044e\u0447\u0430\u0442\u044c, \u0442\u0435\u043c \u0441\u0430\u043c\u044b\u043c \u043c\u0435\u043d\u044f\u044f \u043b\u043e\u0433\u0438\u043a\u0443 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e \u043d\u0438\u0445 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0447\u0435\u0441\u0442\u044c \u0437\u0434\u0435\u0441\u044c.<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[9,10],"tags":[],"class_list":["post-4970","post","type-post","status-publish","format-standard","hentry","category-databases","category-others"],"_links":{"self":[{"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=\/wp\/v2\/posts\/4970","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=4970"}],"version-history":[{"count":4,"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=\/wp\/v2\/posts\/4970\/revisions"}],"predecessor-version":[{"id":5020,"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=\/wp\/v2\/posts\/4970\/revisions\/5020"}],"wp:attachment":[{"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=4970"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=4970"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/skeletor.org.ua\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=4970"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}