{"id":480830,"date":"2026-05-24T19:21:08","date_gmt":"2026-05-24T19:21:08","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=480830"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=480830","title":{"rendered":"\u041f\u043e\u0447\u0435\u043c\u0443 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u044e\u0442 join_collapse_limit = 20"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u0412 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u0438 \u043f\u043e\u0434 \u0441\u0442\u0430\u0442\u044c\u044f\u043c\u0438 &#171;<a href=\"https:\/\/habr.com\/ru\/companies\/tantor\/articles\/1035568\/#comment_29978522\" rel=\"noopener noreferrer nofollow\">\u0421\u0423\u0411\u0414 Tantor Postgres 18: \u043e\u0431\u0437\u043e\u0440 \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u0439 \u0434\u043b\u044f 1\u0421<\/a>&#187; \u0438 &#171;<a href=\"https:\/\/habr.com\/ru\/companies\/postgrespro\/articles\/1037080\/#comment_30008186\" rel=\"noopener noreferrer nofollow\">\u0412 \u043f\u043e\u0433\u043e\u043d\u0435 \u0437\u0430 APDEX-\u043e\u043c, \u0438\u043b\u0438 \u043a\u0430\u043a \u0441\u043e\u0437\u0434\u0430\u0442\u044c HighLoad \u043d\u0430 \u043d\u0435\u0434\u043e\u0440\u043e\u0433\u043e\u043c \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u043e\u043c \u0436\u0435\u043b\u0435\u0437\u0435<\/a>&#187; \u0447\u0440\u0435\u0437\u0432\u044b\u0447\u0430\u0439\u043d\u043e \u0443\u0432\u0430\u0436\u0430\u0435\u043c\u044b\u0435 \u043b\u044e\u0434\u0438 \u0437\u0430\u0434\u0430\u043b\u0438\u0441\u044c \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u043c \u043f\u0440\u043e *_collapse_limit \u0438 \u0435\u0433\u043e \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u043a geqo_threshold. \u0412 \u0441\u043e\u043e\u0431\u0449\u0435\u0441\u0442\u0432\u0435 \u043e\u0431\u0441\u0443\u0436\u0434\u0430\u043b\u0438 \u044d\u0442\u0438 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u043c \u0442\u043e\u043f\u0438\u043a\u0435, \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043a\u043e\u0440\u043e\u0442\u043a\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u043e \u0442\u043e, \u043a \u0447\u0435\u043c\u0443 \u0442\u0430\u043c \u043f\u0440\u0438\u0448\u043b\u0438.<\/p>\n<p>\u0427\u0438\u0441\u043b\u043e 20 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0438\u0437 <a href=\"https:\/\/www.postgresql.org\/message-id\/flat\/200907121457.54132.andres%40anarazel.de#754b04d74fb4113a7461cf93c4bcb970\" rel=\"noopener noreferrer nofollow\">\u043f\u043e\u0441\u0442\u0430<\/a> \u0420\u043e\u0431\u0435\u0440\u0442\u0430 \u0425\u0430\u0430\u0441\u0430 2009 \u0433\u043e\u0434\u0430 \u043f\u043e \u0442\u043e, \u043c\u043e\u0436\u043d\u043e \u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 *_collapse_limit \u0432 PostgreSQL \u0432\u0435\u0440\u0441\u0438\u0438 8.5, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432 \u0442\u043e \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u0445\u043e\u0434\u0438\u043b\u0430. <em>\u0422\u0435\u0445\u043d\u0438\u043a\u0430 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f <\/em><a href=\"https:\/\/www.cybertec-postgresql.com\/en\/forcing-a-join-order-in-postgresql\/\" rel=\"noopener noreferrer nofollow\"><em>OFFSET 0<\/em><\/a><em> \u0432\u0437\u044f\u043b\u0430\u0441\u044c \u0438\u0437 \u0442\u043e\u0433\u043e \u0436\u0435 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u044f<\/em>.<\/p>\n<p>\u0412 2009 \u0433\u043e\u0434\u0443 \u0425\u0430\u0430\u0441 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0438\u043b \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c geqo_threshold \u0434\u043e 16 \u0438 *_collapse_limit \u0434\u043e 12 (\u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u0443\u043b\u0435\u0432\u044b\u043c\u0438 \u0438\u043b\u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0443\u0431\u0440\u0430\u0442\u044c), \u0438 \u0441\u043f\u0440\u043e\u0441\u0438\u043b \u043c\u043d\u0435\u043d\u0438\u0435 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u043e\u0432. GEQO \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0432 PostgreSQL 19 \u0444\u0435\u0432\u0440\u0430\u043b\u044f 1997 \u0433\u043e\u0434\u0430.<\/p>\n<p>\u041f\u0440\u0430\u043a\u0442\u0438\u043a, \u041a\u0435\u0432\u0438\u043d \u0413\u0440\u0438\u0442\u0442\u043d\u0435\u0440, \u043d\u0430\u043f\u0438\u0441\u0430\u043b: \u0443 \u043d\u0430\u0441 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d geqo, \u0438 \u043c\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0438 <em>_collapse_limit \u043d\u0430 20. \u0412\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u043d\u0430\u043c \u0441\u043b\u0435\u0434\u0443\u0435\u0442 <\/em><strong><em>\u043f\u0440\u043e\u0441\u0442\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0438\u0445 \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u043e\u0442\u0435\u043d<\/em><\/strong><em> \u0438 \u043d\u0435 \u0436\u0434\u0430\u0442\u044c, \u043f\u043e\u043a\u0430 \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u0441 \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c 20 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438\u00a0\u043d\u0430\u0447\u043d\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043f\u043b\u043e\u0445\u043e, \u043d\u043e \u044f \u043d\u0435 \u0443\u0432\u0435\u0440\u0435\u043d, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u043f\u043e\u043a\u0430 \u0435\u0441\u0442\u044c \u0442\u0430\u043a\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b. \u041f\u043e \u0435\u0433\u043e \u043e\u043f\u044b\u0442\u0443, \u0432 \u0442\u0435\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445, \u043a\u043e\u0433\u0434\u0430 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435 <\/em>_collapse_limit\u00a0\u0445\u043e\u0442\u044c \u043a\u0430\u043a-\u0442\u043e \u0432\u043b\u0438\u044f\u043b\u043e \u043d\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u044d\u0442\u043e \u0432\u0441\u0435\u0433\u0434\u0430 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u043b\u043e \u043a \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u043f\u043b\u0430\u043d\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u043b \u0431\u043e\u043b\u044c\u0448\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0438,\u00a0\u0447\u0435\u043c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435.<\/p>\n<p>\u0420\u043e\u0431\u0435\u0440\u0442 \u0425\u0430\u0430\u0441 \u0432\u044b\u0440\u0430\u0437\u0438\u043b \u0441\u0443\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432: \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b join_collapse_limit \u0438 from_collapse_limit \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0442 \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f. <strong>\u0415\u0441\u043b\u0438 \u0432\u0441\u0435 \u043e\u0446\u0435\u043d\u043a\u0438 \u0432\u0435\u0440\u043d\u044b, \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0438\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f &lt; \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0441\u0442\u0438\u00a0 \u043b\u0438\u0431\u043e \u043e\u0441\u0442\u0430\u0432\u0438\u0442 \u043f\u043b\u0430\u043d\u044b \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u043d\u044b\u043c\u0438, \u043b\u0438\u0431\u043e \u0443\u0445\u0443\u0434\u0448\u0438\u0442 \u0438\u0445<\/strong>. \u0415\u0441\u043b\u0438 \u0436\u0435 \u043e\u043d\u0438 \u0443\u043b\u0443\u0447\u0448\u0430\u0442 \u043f\u043b\u0430\u043d\u044b, \u0437\u043d\u0430\u0447\u0438\u0442, \u043e\u0446\u0435\u043d\u043a\u0438 \u043d\u0435\u0432\u0435\u0440\u043d\u044b, \u0438\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u043c\u0435\u0448\u0430\u0435\u0442 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0443 \u0443\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c\u00a0\u0441\u043b\u0443\u0447\u0430\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430\u043d\u043e\u0441\u044f\u0442 \u0443\u0449\u0435\u0440\u0431. \u041d\u043e \u044d\u0442\u043e \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c \u0434\u0435\u043b\u043e \u0441\u043b\u0443\u0447\u0430\u044f.<\/p>\n<p><em>\u0422\u043e \u0435\u0441\u0442\u044c \u0447\u0442\u043e 20, \u0447\u0442\u043e 100 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u043d\u0435\u0442, \u0435\u0441\u043b\u0438 \u043e\u0446\u0435\u043d\u043a\u0438 \u0432\u0435\u0440\u043d\u044b. \u0421\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u0443\u043b\u0435\u0432\u044b\u043c\u0438 \u0445\u043e\u0442\u0435\u043b\u0438, \u0447\u0442\u043e\u0431\u044b \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u0442\u043e\u0447\u043d\u043e \u0442\u0430\u043a\u0438\u043c, \u043a\u0430\u043a \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u0435.<\/em><\/p>\n<p>\u0422\u043e\u043c \u041b\u0435\u0439\u043d \u043d\u0430\u043f\u0438\u0441\u0430\u043b, \u0447\u0442\u043e *_collapse_limit \u0431\u044b\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u044b \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043a\u043e\u043c\u0443-\u0442\u043e \u043e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442\u00a0\u043f\u0440\u0438\u0433\u043e\u0434\u0438\u0442\u044c\u0441\u044f. \u0422\u043e\u043c \u043d\u0435 \u043f\u0440\u043e\u0442\u0438\u0432 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f join_collapse_limit \u0438\u043b\u0438 \u0441\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u0435\u0433\u043e \u043a \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u043c\u0443 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044e.<\/p>\n<p>\u0410\u043b\u044c\u0432\u0430\u0440\u043e \u042d\u0440\u0440\u0435\u0440\u0430 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u043b\u0441\u044f \u0441\u043e \u0441\u043b\u0443\u0447\u0430\u044f\u043c\u0438, \u043a\u043e\u0433\u0434\u0430 collapse_limits \u0431\u044b\u043b\u0438 \u0431\u044b\u00a0 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u043c\u0438 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430\u043c\u0438.<\/p>\n<p>\u041d\u043e\u0430 \u041c\u0438\u0448 \u0434\u043e\u043d\u0435\u0441 \u043c\u0438\u0440\u0443 \u0442\u043e, \u0447\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 <strong>\u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0440\u0430\u0437\u043b\u0438\u0447\u0438\u043c\u044b\u0445<\/strong> \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432 \u043d\u0430 PostgreSQL 8.3 \u043e\u043d \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0435\u0442 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432 4 \u0440\u0430\u0437\u0430 (<em>\u0412 PostgreSQL 18 \u0432 3.x \u0440\u0430\u0437 \u0438\u043b\u0438, \u043a\u0430\u043a \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e <\/em><a href=\"https:\/\/habr.com\/ru\/companies\/tantor\/articles\/1036274\/\" rel=\"noopener noreferrer nofollow\"><em>\u043f\u0438\u0448\u0435\u0442<\/em><\/a><em> \u0410\u043d\u0434\u0440\u0435\u0439 \u041b\u0435\u043f\u0438\u0445\u043e\u0432\u00a0&#171;\u0441\u0432\u0435\u0440\u0445\u044d\u043a\u0441\u043f\u043e\u043d\u0435\u043d\u0446\u0438\u0430\u043b\u044c\u043d\u043e&#187;<\/em>) \u0438 \u043f\u0440\u0438\u0432\u0435\u043b \u043f\u0440\u0438\u043c\u0435\u0440 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f 16 \u0442\u0430\u0431\u043b\u0438\u0446. \u0410 \u0434\u043b\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0441 19-21 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f\u043c\u0438, \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0437\u043c (<em>\u0432\u043a\u043b\u044e\u0447\u0438\u0442\u044c GEQO<\/em>),\u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0434\u043b\u0438\u043b\u043e\u0441\u044c \u0431\u043e\u043b\u0435\u0435, \u0447\u0435\u043c 600 \u0441\u0435\u043a\u0443\u043d\u0434 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u043e \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043f\u043b\u0430\u043d\u0438\u0440\u0432\u0430\u043d\u0438\u044f <strong>\u0431\u043e\u043b\u0435\u0435 10 \u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438<\/strong>. \u041d\u043e\u0430 \u041c\u0438\u0448 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u043b\u0441\u044f \u0441 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0435\u0439, \u043a\u043e\u0433\u0434\u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u043e\u0442\u043b\u0438\u0447\u043d\u043e\u0435 \u043e\u0442\u00a01 \u0438\u043b\u0438 &#171;\u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0441\u0442\u044c&#187;, \u0434\u043b\u044f *_collapse_limit, \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0431\u044b \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c.<\/p>\n<p>\u0422\u043e\u043c \u041b\u0435\u0439\u043d \u0441\u043a\u0430\u0437\u0430\u043b, \u0447\u0442\u043e DBA \u043b\u044e\u0431\u044f\u0442 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e\u0441\u0442\u044c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u043e-\u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u0434\u043b\u044f join_collapse_limit \u0438 from_collapse_limit \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u044b \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u0435\u0434\u043e\u0442\u0432\u0440\u0430\u0442\u0438\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 GEQO. \u00a0\u0415\u0441\u043b\u0438 \u0443\u0431\u0440\u0430\u0442\u044c *_collapse_limit, \u0442\u043e \u043f\u043e\u0441\u044b\u043f\u044f\u0442\u0441\u044f \u0436\u0430\u043b\u043e\u0431\u044b, \u0447\u0442\u043e \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f, \u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0442\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e, \u0435\u0441\u043b\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435 \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c GEQO \u0438 \u0441\u043e\u0441\u043b\u0430\u043b\u0441\u044f \u043d\u0430 \u043d\u0435\u0434\u0430\u0432\u043d\u044e\u044e \u0436\u0430\u043b\u043e\u0431\u0443 \u0441 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435\u043c 17 \u0442\u0430\u0431\u043b\u0438\u0446.<\/p>\n<p>\u041c\u043d\u0435\u043d\u0438\u0435 \u0422\u043e\u043c\u0430 \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u043b \u041a\u0435\u0432\u0438\u043d \u0413\u0440\u0438\u0442\u0442\u043d\u0435\u0440 (\u043a\u0430\u043a \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u0435\u043b\u044c DBA \u0432 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u0438), \u0447\u0442\u043e \u0433\u043b\u0430\u0432\u043d\u0430\u044f \u043f\u0440\u0438\u0447\u0438\u043d\u0430, \u043f\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043e\u043d \u0441\u0442\u0430\u0440\u0430\u0435\u0442\u0441\u044f \u0438\u0437\u0431\u0435\u0433\u0430\u0442\u044c GEQO, \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0437\u043d\u0430\u0435\u0442, GEQO \u043c\u043e\u0436\u0435\u0442 \u0440\u0435\u0434\u043a\u043e, \u043d\u043e \u043c\u0435\u0442\u043a\u043e, \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u0440\u0438\u0432\u043e\u0439 \u043f\u043b\u0430\u043d, \u0447\u0442\u043e \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043a \u0437\u0430\u0433\u0430\u0434\u043e\u0447\u043d\u044b\u043c \u0436\u0430\u043b\u043e\u0431\u0430\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439, \u0438 \u044d\u0442\u0438 \u0436\u0430\u043b\u043e\u0431\u044b \u043c\u043e\u0433\u0443\u0442 \u043e\u0442\u043d\u044f\u0442\u044c \u043c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043d\u0430 \u0440\u0430\u0437\u0431\u043e\u0440 \u043f\u0440\u0438\u0447\u0438\u043d.<\/p>\n<p>\u0410\u043d\u0434\u0440\u0435\u0430\u0441 \u0424\u0440\u043e\u0439\u043d\u0434 \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u043d\u0435\u0439 \u0438 \u0441\u043e\u0437\u0434\u0430\u043b \u0441\u043b\u043e\u0436\u043d\u044b\u0439 \u0442\u0435\u0441\u0442\u043a\u0435\u0439\u0441 \u0438\u0437 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0438 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b \u0432 \u0442\u043e\u043f\u0438\u043a\u0435. \u041b\u044e\u0431\u043e\u0439 \u043c\u043e\u0436\u0435\u0442 \u0435\u0433\u043e \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c. \u042f \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0451\u043b \u043d\u0430 18 \u0432\u0435\u0440\u0441\u0438\u0438 \u0442\u0435\u0441\u0442 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430:<\/p>\n<pre><code class=\"pgsql\">\\timing on \\\\SET SEARCH_PATH = test_data, test_view;SET geqo = off;SET join_collapse_limit = 11;--- 2617.020 ms Memory: used=597053kB  allocated=599284kBSET join_collapse_limit = 12;--- 3205.557 ms used=759366kB  allocated=763124kBSET join_collapse_limit = 13;--- 3266.530 ms used=769482kB  allocated=771316kBSET join_collapse_limit = 14;--- 7079.614 ms used=1090170kB  allocated=1091380kBSET join_collapse_limit = 15;--- 15926.589 ms used=2179803kB  allocated=2181044kBSET join_collapse_limit = 16;--- 13124.880 ms used=2210545kB  allocated=2213812kBSET join_collapse_limit = 17;--- 19529.137 ms used=2793452kB  allocated=2796724kBSET join_collapse_limit = 18;--- 63925.147 ms used=8861636kB  allocated=8869044kBSET join_collapse_limit = 19;--- 56204.530 ms used=8861646kB  allocated=8869044kBSET join_collapse_limit = 20;--- 85993.891 ms used=11677634kB  allocated=11679733kBSET geqo = off;SET join_collapse_limit = 21;--- \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u0438.<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043d\u0430 \u0442\u0435\u0441\u0442\u0435 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0424\u0440\u043e\u0439\u043d\u0434\u0430, \u043f\u0430\u043c\u044f\u0442\u044c \u0438 \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u043e\u0441\u044c \u0441\u043a\u0430\u0447\u043a\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a, \u0441 11\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u0430\u0441\u044c \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u043c \u043d\u0430 \u0432\u0440\u0435\u043c\u044f \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u043b \u043f\u043e\u0441\u043b\u0435 join_collapse_limit = 20. \u041d\u0435\u0445\u0432\u0430\u0442\u043a\u0430 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442, \u043a\u0430\u043a \u043f\u043e\u0434\u0432\u0438\u0441\u0430\u043d\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b (\u0438\u0437-\u0437\u0430 \u043a\u044d\u0448\u0435\u0439) \u0438 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u044f\u043a\u043e\u0431\u044b \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440 \u0441\u0438\u043b\u044c\u043d\u043e \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f.<\/p>\n<p>\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u0442\u0441\u044e\u0434\u0430 \u0438 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0447\u0438\u0441\u043b\u043e 20. \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u0441\u0442\u0430\u043b\u0438, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0438\u0437 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043f\u0440\u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u043c GEQO \u0441\u0438\u0441\u0442\u0441\u0435\u043c\u0430 \u0445\u043e\u0442\u044f \u0431\u044b \u043d\u0435 \u043f\u043e\u0434\u0432\u0438\u0441\u043d\u0435\u0442 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0445\u0432\u0430\u0442\u0438\u0442. \u0422\u043e \u0435\u0441\u0442\u044c *_collapse_limit = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430\u044f \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u0447\u0438\u0441\u0442\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u0449\u0438\u0442\u0438\u0442\u044c\u0441\u044f \u043e\u0442 geqo = off.<\/p>\n<p>\u041d\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0438 \u041a\u0435\u0432\u0438\u043d\u0430 \u0434\u043b\u044f \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0445 \u0431\u0438\u0437\u043d\u0435\u0441-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0418\u043d\u0442\u0435\u0440\u0435\u0441\u0435\u043d \u0433\u0440\u0430\u043d\u0438\u0447\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0439 \u041d\u043e\u0430 \u041c\u0438\u0448. \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u0434\u043b\u044f join_colapse_limit \u0441\u043e \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0440\u0430\u0437\u043b\u0438\u0447\u0438\u043c\u044b\u043c\u0438 \u0441\u0442\u043e\u043b\u0431\u0430\u043c\u0438:<\/p>\n<pre><code class=\"pgsql\">\\timing on \\\\SET geqo = on;SET geqo_threshold = 16;SET join_collapse_limit = 16;EXPLAIN (analyze, memory, settings) with t as (select 1 a)select 1 from t t0 natural join t t1 natural join t t2 natural join tt3 natural join t t4 natural join t t5 natural join t t6 natural join t t7natural join t t8 natural join t t9 natural join t t10 natural join t t11natural join t t12 natural join t t13 natural join t t14;Settings: geqo_threshold = '15', join_collapse_limit = '15' Planning:   Memory: used=235kB  allocated=256kB Planning Time: 33.668 ms Execution Time: 0.328 msSettings: geqo_threshold = '15', join_collapse_limit = '14' Planning:   Memory: used=5155822kB  allocated=5162241kB Planning Time: 18779.568 ms Execution Time: 0.410 msSettings: geqo_threshold = '15', join_collapse_limit = '13' Planning:   Memory: used=1680916kB  allocated=1688193kB Planning Time: 5986.123 ms Execution Time: 0.409 msSettings: geqo_threshold = '15', join_collapse_limit = '12' Planning:   Memory: used=546392kB  allocated=549153kB Planning Time: 1937.615 ms Execution Time: 0.395 ms\u0422\u043e \u0435\u0441\u0442\u044c \u0445\u0443\u0434\u0448\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043a\u043e\u0433\u0434\u0430 *_collapse_limit \u043c\u0435\u043d\u044c\u0448\u0435 geqo_threshold \u043d\u0430 \u0435\u0434\u0438\u043d\u0438\u0446\u0443.\u041f\u0440\u0438 geqo_threshold = '16', join_collapse_limit = '15' \u0432\u044b\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f 15\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438, \u0447\u0442\u043e \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043d\u043e\u0433\u043e.Planning Time: 41241.285 ms Memory: used=15761345kB<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0420\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f *_collapse_limit = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430. \u0415\u0441\u043b\u0438 \u043d\u0435 \u043e\u0442\u043a\u043b\u044e\u0447\u0430\u0442\u044c GEQO \u0438 \u043d\u0435 \u043c\u0435\u043d\u044f\u0442\u044c geqo_threshold, \u0442\u043e \u0435\u0433\u043e \u0434\u0430\u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c 30, 40. \u041d\u0430 \u044d\u0442\u043e \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u0442\u043e\u0440\u043e\u0439 \u0433\u0440\u0430\u0444\u0438\u043a \u0432 <a href=\"https:\/\/ptolmachev.ru\/xabr-kak-rabotaet-optimizator-postgresql-pri-bolshom-kolichestve-tablic-v-zaprose.html\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u041f\u0430\u0432\u043b\u0430 \u0422\u043e\u043b\u043c\u0430\u0447\u0451\u0432\u0430. \u0425\u043e\u0440\u043e\u0448\u0438\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0442\u0430\u043a\u0436\u0435 \u0435\u0441\u0442\u044c \u0432 <a href=\"https:\/\/habr.com\/ru\/articles\/943050\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a>.<\/p>\n<p>\u041e\u0441\u0442\u0430\u043b\u0441\u044f \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u0432\u043e\u043f\u0440\u043e\u0441 (<s>\u043a\u0442\u043e \u0443\u0431\u0438\u043b \u043c\u0438\u0441\u0442\u0435\u0440\u0430 \u041d\u043e\u043b\u0435\u0441\u0442\u0440\u043e<\/s>): \u043d\u0443\u0436\u043d\u043e \u043b\u0438 \u0441\u0442\u0430\u0432\u0438\u0442\u044c *_collapse_limit \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c geqo_threshold, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 12. \u0414\u0430, \u043d\u0443\u0436\u043d\u043e. \u0412 1\u0421 \u0431\u044b\u043b\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430, \u043a\u043e\u0433\u0434\u0430 \u0432 \u043a\u043e\u043d\u0435\u0446 \u00a0\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0447\u0438\u0441\u043b\u043e\u043c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0434\u043e\u0431\u0430\u0432\u0430\u043b\u044f\u043b\u0441\u044f &#171;<code>ANDt1.col1 IN ( VALUES(..<\/code>&#171;. \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043e\u043f\u0438\u0441\u0430\u043d\u0430 \u0432 <a href=\"https:\/\/infostart.ru\/1c\/articles\/2231019\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440\u0430 \u0421\u0438\u043c\u043e\u043d\u043e\u0432\u0430. \u0410\u043d\u0434\u0440\u0435\u0439 \u041b\u0435\u043f\u0438\u0445\u043e\u0432 \u0438 \u0410\u043b\u0451\u043d\u0430 \u0420\u044b\u0431\u0430\u043a\u0438\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 <a href=\"https:\/\/www.postgresql.org\/message-id\/flat\/0184212d-1248-4f1f-a42d-f5cb1c1976d2%40tantorlabs.com\" rel=\"noopener noreferrer nofollow\">\u043f\u0430\u0442\u0447<\/a> (\u0440\u0435\u0432\u044c\u044e\u0432\u0435\u0440\u044b \u0418\u0432\u0430\u043d \u041a\u0443\u0448\u043d\u0430\u0440\u0435\u043d\u043a\u043e \u0438 \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440 \u041a\u043e\u0440\u043e\u0442\u043a\u043e\u0432), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0447\u0440\u0435\u0437\u0432\u044b\u0447\u0430\u0439\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0431\u044b\u043b \u0437\u0430\u043a\u043e\u043c\u043c\u0438\u0447\u0435\u043d \u0422\u043e\u043c\u043e\u043c \u041b\u0435\u0439\u043d\u043e\u043c. \u042d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0443\u0448\u043b\u0430, \u043d\u043e *_collapse_limit \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0435 \u0432 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0431\u043e\u043b\u044c\u0448\u0435\u0435 geqo_threshold, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0443 \u0441\u043e\u0435\u0434\u0438\u043d\u0438\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u0438\u0437 \u043d\u0430\u0447\u0430\u043b\u0430 \u0438 \u043a\u043e\u043d\u0446\u0430 \u0441\u043f\u0438\u0441\u043a\u0430 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0438\u043b\u0438 \u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u043e\u0432. \u0413\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u043b\u0438 1\u0421 \u0441\u0435\u0439\u0447\u0430\u0441 \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0433\u0434\u0435 \u044d\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u044f \u043d\u0435 \u0437\u043d\u0430\u044e, \u043d\u043e \u0434\u043e \u043f\u0430\u0442\u0447\u0430 \u043d\u0430 VALUES \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b. \u0414\u0430\u0435\u0442 \u043b\u0438 \u043c\u0438\u043d\u0443\u0441\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 *_collapse_limit \u0432 \u0447\u0443\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0447\u0435\u043c 20? \u041f\u043e \u0433\u0440\u0430\u0444\u0438\u043a\u0443 \u0438\u0437 \u0441\u0442\u0430\u0442\u044c\u0438 \u041f\u0430\u0432\u043b\u0430 \u0422\u043e\u043b\u043c\u0430\u0447\u0435\u0432\u0430 \u043f\u043e\u0447\u0442\u0438 \u043d\u0435\u0442. \u041f\u043b\u0430\u043d\u044b \u043d\u0435 \u0443\u043b\u0443\u0447\u0448\u0438\u0442 (\u0435\u0441\u043b\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435\u0442 \u043e\u0448\u0438\u0431\u043e\u043a \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0430).<\/p>\n<p>\u042f \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0451\u043b \u043d\u0430 18 \u0432\u0435\u0440\u0441\u0438\u0438 \u0442\u0435\u0441\u0442 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430:<\/p>\n<pre><code class=\"pgsql\">\\timing on \\\\SET SEARCH_PATH = test_data, test_view;SET geqo = off;SET join_collapse_limit = 11;--- 2617.020 ms Memory: used=597053kB  allocated=599284kBSET join_collapse_limit = 12;--- 3205.557 ms used=759366kB  allocated=763124kBSET join_collapse_limit = 13;--- 3266.530 ms used=769482kB  allocated=771316kBSET join_collapse_limit = 14;--- 7079.614 ms used=1090170kB  allocated=1091380kBSET join_collapse_limit = 15;--- 15926.589 ms used=2179803kB  allocated=2181044kBSET join_collapse_limit = 16;--- 13124.880 ms used=2210545kB  allocated=2213812kBSET join_collapse_limit = 17;--- 19529.137 ms used=2793452kB  allocated=2796724kBSET join_collapse_limit = 18;--- 63925.147 ms used=8861636kB  allocated=8869044kBSET join_collapse_limit = 19;--- 56204.530 ms used=8861646kB  allocated=8869044kBSET join_collapse_limit = 20;--- 85993.891 ms used=11677634kB  allocated=11679733kBSET geqo = off;SET join_collapse_limit = 21;--- \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u0438<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043d\u0430 \u0442\u0435\u0441\u0442\u0435 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0424\u0440\u043e\u0439\u043d\u0434\u0430, \u043f\u0430\u043c\u044f\u0442\u044c \u0438 \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u043e\u0441\u044c \u0441\u043a\u0430\u0447\u043a\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a, \u0441 11\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u0430\u0441\u044c \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u043c \u043d\u0430 \u0432\u0440\u0435\u043c\u044f \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u043b \u043f\u043e\u0441\u043b\u0435 join_collapse_limit = 20. \u041d\u0435\u0445\u0432\u0430\u0442\u043a\u0430 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442, \u043a\u0430\u043a \u043f\u043e\u0434\u0432\u0438\u0441\u0430\u043d\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b (\u0438\u0437-\u0437\u0430 \u043a\u044d\u0448\u0435\u0439) \u0438 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u044f\u043a\u043e\u0431\u044b \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440 \u0441\u0438\u043b\u044c\u043d\u043e \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f.<\/p>\n<p>\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u0442\u0441\u044e\u0434\u0430 \u0438 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0447\u0438\u0441\u043b\u043e 20. \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u0441\u0442\u0430\u043b\u0438, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0438\u0437 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043f\u0440\u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u043c GEQO \u0441\u0438\u0441\u0442\u0441\u0435\u043c\u0430 \u0445\u043e\u0442\u044f \u0431\u044b \u043d\u0435 \u043f\u043e\u0434\u0432\u0438\u0441\u043d\u0435\u0442 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0445\u0432\u0430\u0442\u0438\u0442. \u0422\u043e \u0435\u0441\u0442\u044c *_collapse_limit = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430\u044f \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u0447\u0438\u0441\u0442\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u0449\u0438\u0442\u0438\u0442\u044c\u0441\u044f \u043e\u0442 geqo = off.<\/p>\n<p>\u041d\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0438 \u041a\u0435\u0432\u0438\u043d\u0430 \u0434\u043b\u044f \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0445 \u0431\u0438\u0437\u043d\u0435\u0441-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0418\u043d\u0442\u0435\u0440\u0435\u0441\u0435\u043d \u0433\u0440\u0430\u043d\u0438\u0447\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0439 \u041d\u043e\u0430 \u041c\u0438\u0448. \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u0434\u043b\u044f join_colapse_limit \u0441\u043e \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0440\u0430\u0437\u043b\u0438\u0447\u0438\u043c\u044b\u043c\u0438 \u0441\u0442\u043e\u043b\u0431\u0430\u043c\u0438:<\/p>\n<pre><code class=\"pgsql\">\\timing on \\\\SET geqo = on;SET geqo_threshold = 16;SET join_collapse_limit = 16;EXPLAIN (analyze, memory, settings) with t as (select 1 a)select 1 from t t0 natural join t t1 natural join t t2 natural join tt3 natural join t t4 natural join t t5 natural join t t6 natural join t t7natural join t t8 natural join t t9 natural join t t10 natural join t t11natural join t t12 natural join t t13 natural join t t14;Settings: geqo_threshold = '15', join_collapse_limit = '15' Planning:   Memory: used=235kB  allocated=256kB Planning Time: 33.668 ms Execution Time: 0.328 msSettings: geqo_threshold = '15', join_collapse_limit = '14' Planning:   Memory: used=5155822kB  allocated=5162241kB Planning Time: 18779.568 ms Execution Time: 0.410 msSettings: geqo_threshold = '15', join_collapse_limit = '13' Planning:   Memory: used=1680916kB  allocated=1688193kB Planning Time: 5986.123 ms Execution Time: 0.409 msSettings: geqo_threshold = '15', join_collapse_limit = '12' Planning:   Memory: used=546392kB  allocated=549153kB Planning Time: 1937.615 ms Execution Time: 0.395 ms<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u0445\u0443\u0434\u0448\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043a\u043e\u0433\u0434\u0430 <code>*_collapse_limit<\/code> \u043c\u0435\u043d\u044c\u0448\u0435 geqo_threshold \u043d\u0430 \u0435\u0434\u0438\u043d\u0438\u0446\u0443.<\/p>\n<p>\u041f\u0440\u0438 <code>geqo_threshold = '16', join_collapse_limit = '15'<\/code> \u0432\u044b\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f <strong>15\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438<\/strong>, \u0447\u0442\u043e \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043d\u043e\u0433\u043e:<\/p>\n<p><code> Planning Time: 41241.285 ms Memory: used=15761345kB<\/code><\/p>\n<p>\u0420\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f <code>_collapse_limit<\/code> = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430. \u0415\u0441\u043b\u0438 \u043d\u0435 \u043e\u0442\u043a\u043b\u044e\u0447\u0430\u0442\u044c GEQO \u0438 \u043d\u0435 \u043c\u0435\u043d\u044f\u0442\u044c <code>geqo_threshold<\/code>, \u0442\u043e \u0435\u0433\u043e \u0434\u0430\u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c 30, 40&#8230; \u041d\u0430 \u044d\u0442\u043e \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u0442\u043e\u0440\u043e\u0439 \u0433\u0440\u0430\u0444\u0438\u043a \u0432 <a href=\"https:\/\/ptolmachev.ru\/xabr-kak-rabotaet-optimizator-postgresql-pri-bolshom-kolichestve-tablic-v-zaprose.html\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u041f\u0430\u0432\u043b\u0430 \u0422\u043e\u043b\u043c\u0430\u0447\u0451\u0432\u0430. \u0425\u043e\u0440\u043e\u0448\u0438\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0435\u0441\u0442\u044c \u0442\u0430\u043a\u0436\u0435 \u0432 <a href=\"https:\/\/habr.com\/ru\/articles\/943050\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a>.<\/p>\n<p>\u041e\u0441\u0442\u0430\u043b\u0441\u044f \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u0432\u043e\u043f\u0440\u043e\u0441 (<s>\u043a\u0442\u043e \u0443\u0431\u0438\u043b \u043c\u0438\u0441\u0442\u0435\u0440\u0430 \u041d\u043e\u043b\u0435\u0441\u0442\u0440\u043e<\/s>): \u0438\u043c\u0435\u0435\u0442 \u043b\u0438 \u0441\u043c\u044b\u0441\u043b \u0441\u0442\u0430\u0432\u0438\u0442\u044c <code>_collapse_limit<\/code>  \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c <code>geqo_threshold<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 12. \u0418\u043c\u0435\u0435\u0442. \u0412 1\u0421 \u0431\u044b\u043b\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430, \u043a\u043e\u0433\u0434\u0430 \u0432 \u043a\u043e\u043d\u0435\u0446 \u00a0\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0447\u0438\u0441\u043b\u043e\u043c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0434\u043e\u0431\u0430\u0432\u0430\u043b\u044f\u043b\u0441\u044f &#171;<code>ANDt1.col1 IN ( VALUES(..<\/code>&#171;. \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043e\u043f\u0438\u0441\u0430\u043d\u0430 \u0432 <a href=\"https:\/\/infostart.ru\/1c\/articles\/2231019\/\" rel=\"noopener noreferrer nofollow\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440\u0430 \u0421\u0438\u043c\u043e\u043d\u043e\u0432\u0430. \u0410\u043d\u0434\u0440\u0435\u0439 \u041b\u0435\u043f\u0438\u0445\u043e\u0432 \u0438 \u0410\u043b\u0451\u043d\u0430 \u0420\u044b\u0431\u0430\u043a\u0438\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 <a href=\"https:\/\/www.postgresql.org\/message-id\/flat\/0184212d-1248-4f1f-a42d-f5cb1c1976d2%40tantorlabs.com\" rel=\"noopener noreferrer nofollow\">\u043f\u0430\u0442\u0447<\/a> (\u0440\u0435\u0432\u044c\u044e\u0432\u0435\u0440\u044b \u0418\u0432\u0430\u043d \u041a\u0443\u0448\u043d\u0430\u0440\u0435\u043d\u043a\u043e \u0438 \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440 \u041a\u043e\u0440\u043e\u0442\u043a\u043e\u0432), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0447\u0440\u0435\u0437\u0432\u044b\u0447\u0430\u0439\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0431\u044b\u043b \u0437\u0430\u043a\u043e\u043c\u043c\u0438\u0447\u0435\u043d \u0422\u043e\u043c\u043e\u043c \u041b\u0435\u0439\u043d\u043e\u043c. \u042d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0443\u0448\u043b\u0430, \u043d\u043e <code>*_collapse_limit<\/code> \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0435 \u0432 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0431\u043e\u043b\u044c\u0448\u0435\u0435 <code>geqo_threshold<\/code>, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0443 \u0441\u043e\u0435\u0434\u0438\u043d\u0438\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u0438\u0437 \u043d\u0430\u0447\u0430\u043b\u0430 \u0438 \u043a\u043e\u043d\u0446\u0430 \u0441\u043f\u0438\u0441\u043a\u0430 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0438\u043b\u0438 \u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u043e\u0432. \u0413\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u043b\u0438 1\u0421 \u0441\u0435\u0439\u0447\u0430\u0441 \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0433\u0434\u0435 \u044d\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u044f \u043d\u0435 \u0437\u043d\u0430\u044e, \u043d\u043e \u0434\u043e \u043f\u0430\u0442\u0447\u0430 \u043d\u0430 VALUES \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b. \u0414\u0430\u0435\u0442 \u043b\u0438 \u043c\u0438\u043d\u0443\u0441\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 <code>_collapse_limit<\/code>  \u0432 \u0447\u0443\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0447\u0435\u043c 20? \u041f\u043e \u0433\u0440\u0430\u0444\u0438\u043a\u0443 \u0438\u0437 \u0441\u0442\u0430\u0442\u044c\u0438 \u041f\u0430\u0432\u043b\u0430 \u0422\u043e\u043b\u043c\u0430\u0447\u0435\u0432\u0430 \u043f\u043e\u0447\u0442\u0438 \u043d\u0435\u0442. \u041f\u043b\u0430\u043d\u044b \u043d\u0435 \u0443\u043b\u0443\u0447\u0448\u0438\u0442 (\u0435\u0441\u043b\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435\u0442 \u043e\u0448\u0438\u0431\u043e\u043a \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0430).<\/p>\n<\/div>\n<p>\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1038762\/\">https:\/\/habr.com\/ru\/articles\/1038762\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0412 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u0438 \u043f\u043e\u0434 \u0441\u0442\u0430\u0442\u044c\u044f\u043c\u0438 &#171;\u0421\u0423\u0411\u0414 Tantor Postgres 18: \u043e\u0431\u0437\u043e\u0440 \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u0439 \u0434\u043b\u044f 1\u0421&#187; \u0438 &#171;\u0412 \u043f\u043e\u0433\u043e\u043d\u0435 \u0437\u0430 APDEX-\u043e\u043c, \u0438\u043b\u0438 \u043a\u0430\u043a \u0441\u043e\u0437\u0434\u0430\u0442\u044c HighLoad \u043d\u0430 \u043d\u0435\u0434\u043e\u0440\u043e\u0433\u043e\u043c \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u043e\u043c \u0436\u0435\u043b\u0435\u0437\u0435&#187; \u0447\u0440\u0435\u0437\u0432\u044b\u0447\u0430\u0439\u043d\u043e \u0443\u0432\u0430\u0436\u0430\u0435\u043c\u044b\u0435 \u043b\u044e\u0434\u0438 \u0437\u0430\u0434\u0430\u043b\u0438\u0441\u044c \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u043c \u043f\u0440\u043e *_collapse_limit \u0438 \u0435\u0433\u043e \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435 \u043a geqo_threshold. \u0412 \u0441\u043e\u043e\u0431\u0449\u0435\u0441\u0442\u0432\u0435 \u043e\u0431\u0441\u0443\u0436\u0434\u0430\u043b\u0438 \u044d\u0442\u0438 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u043c \u0442\u043e\u043f\u0438\u043a\u0435, \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043a\u043e\u0440\u043e\u0442\u043a\u043e \u043e\u043f\u0438\u0441\u0430\u043d\u043e \u0442\u043e, \u043a \u0447\u0435\u043c\u0443 \u0442\u0430\u043c \u043f\u0440\u0438\u0448\u043b\u0438.\u0427\u0438\u0441\u043b\u043e 20 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0438\u0437 \u043f\u043e\u0441\u0442\u0430 \u0420\u043e\u0431\u0435\u0440\u0442\u0430 \u0425\u0430\u0430\u0441\u0430 2009 \u0433\u043e\u0434\u0430 \u043f\u043e \u0442\u043e, \u043c\u043e\u0436\u043d\u043e \u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 *_collapse_limit \u0432 PostgreSQL \u0432\u0435\u0440\u0441\u0438\u0438 8.5, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432 \u0442\u043e \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u0445\u043e\u0434\u0438\u043b\u0430. \u0422\u0435\u0445\u043d\u0438\u043a\u0430 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f OFFSET 0 \u0432\u0437\u044f\u043b\u0430\u0441\u044c \u0438\u0437 \u0442\u043e\u0433\u043e \u0436\u0435 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u044f.\u0412 2009 \u0433\u043e\u0434\u0443 \u0425\u0430\u0430\u0441 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0438\u043b \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c geqo_threshold \u0434\u043e 16 \u0438 *_collapse_limit \u0434\u043e 12 (\u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u0443\u043b\u0435\u0432\u044b\u043c\u0438 \u0438\u043b\u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0443\u0431\u0440\u0430\u0442\u044c), \u0438 \u0441\u043f\u0440\u043e\u0441\u0438\u043b \u043c\u043d\u0435\u043d\u0438\u0435 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u043e\u0432. GEQO \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0432 PostgreSQL 19 \u0444\u0435\u0432\u0440\u0430\u043b\u044f 1997 \u0433\u043e\u0434\u0430.\u041f\u0440\u0430\u043a\u0442\u0438\u043a, \u041a\u0435\u0432\u0438\u043d \u0413\u0440\u0438\u0442\u0442\u043d\u0435\u0440, \u043d\u0430\u043f\u0438\u0441\u0430\u043b: \u0443 \u043d\u0430\u0441 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d geqo, \u0438 \u043c\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0438 _collapse_limit \u043d\u0430 20. \u0412\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u043d\u0430\u043c \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u043f\u0440\u043e\u0441\u0442\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0438\u0445 \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u043e\u0442\u0435\u043d \u0438 \u043d\u0435 \u0436\u0434\u0430\u0442\u044c, \u043f\u043e\u043a\u0430 \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u0441 \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c 20 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438\u00a0\u043d\u0430\u0447\u043d\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043f\u043b\u043e\u0445\u043e, \u043d\u043e \u044f \u043d\u0435 \u0443\u0432\u0435\u0440\u0435\u043d, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u043f\u043e\u043a\u0430 \u0435\u0441\u0442\u044c \u0442\u0430\u043a\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b. \u041f\u043e \u0435\u0433\u043e \u043e\u043f\u044b\u0442\u0443, \u0432 \u0442\u0435\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445, \u043a\u043e\u0433\u0434\u0430 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435 _collapse_limit\u00a0\u0445\u043e\u0442\u044c \u043a\u0430\u043a-\u0442\u043e \u0432\u043b\u0438\u044f\u043b\u043e \u043d\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u044d\u0442\u043e \u0432\u0441\u0435\u0433\u0434\u0430 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u043b\u043e \u043a \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u043f\u043b\u0430\u043d\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u043b \u0431\u043e\u043b\u044c\u0448\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0438,\u00a0\u0447\u0435\u043c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435.\u0420\u043e\u0431\u0435\u0440\u0442 \u0425\u0430\u0430\u0441 \u0432\u044b\u0440\u0430\u0437\u0438\u043b \u0441\u0443\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432: \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b join_collapse_limit \u0438 from_collapse_limit \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0442 \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f. \u0415\u0441\u043b\u0438 \u0432\u0441\u0435 \u043e\u0446\u0435\u043d\u043a\u0438 \u0432\u0435\u0440\u043d\u044b, \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0438\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f &lt; \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0441\u0442\u0438\u00a0 \u043b\u0438\u0431\u043e \u043e\u0441\u0442\u0430\u0432\u0438\u0442 \u043f\u043b\u0430\u043d\u044b \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u043d\u044b\u043c\u0438, \u043b\u0438\u0431\u043e \u0443\u0445\u0443\u0434\u0448\u0438\u0442 \u0438\u0445. \u0415\u0441\u043b\u0438 \u0436\u0435 \u043e\u043d\u0438 \u0443\u043b\u0443\u0447\u0448\u0430\u0442 \u043f\u043b\u0430\u043d\u044b, \u0437\u043d\u0430\u0447\u0438\u0442, \u043e\u0446\u0435\u043d\u043a\u0438 \u043d\u0435\u0432\u0435\u0440\u043d\u044b, \u0438\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u043c\u0435\u0448\u0430\u0435\u0442 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0443 \u0443\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c\u00a0\u0441\u043b\u0443\u0447\u0430\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430\u043d\u043e\u0441\u044f\u0442 \u0443\u0449\u0435\u0440\u0431. \u041d\u043e \u044d\u0442\u043e \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c \u0434\u0435\u043b\u043e \u0441\u043b\u0443\u0447\u0430\u044f.\u0422\u043e \u0435\u0441\u0442\u044c \u0447\u0442\u043e 20, \u0447\u0442\u043e 100 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u043d\u0435\u0442, \u0435\u0441\u043b\u0438 \u043e\u0446\u0435\u043d\u043a\u0438 \u0432\u0435\u0440\u043d\u044b. \u0421\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u0443\u043b\u0435\u0432\u044b\u043c\u0438 \u0445\u043e\u0442\u0435\u043b\u0438, \u0447\u0442\u043e\u0431\u044b \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u0442\u043e\u0447\u043d\u043e \u0442\u0430\u043a\u0438\u043c, \u043a\u0430\u043a \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u0435.\u0422\u043e\u043c \u041b\u0435\u0439\u043d \u043d\u0430\u043f\u0438\u0441\u0430\u043b, \u0447\u0442\u043e *_collapse_limit \u0431\u044b\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u044b \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043a\u043e\u043c\u0443-\u0442\u043e \u043e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442\u00a0\u043f\u0440\u0438\u0433\u043e\u0434\u0438\u0442\u044c\u0441\u044f. \u0422\u043e\u043c \u043d\u0435 \u043f\u0440\u043e\u0442\u0438\u0432 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f join_collapse_limit \u0438\u043b\u0438 \u0441\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u0435\u0433\u043e \u043a \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u043c\u0443 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044e.\u0410\u043b\u044c\u0432\u0430\u0440\u043e \u042d\u0440\u0440\u0435\u0440\u0430 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u043b\u0441\u044f \u0441\u043e \u0441\u043b\u0443\u0447\u0430\u044f\u043c\u0438, \u043a\u043e\u0433\u0434\u0430 collapse_limits \u0431\u044b\u043b\u0438 \u0431\u044b\u00a0 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u043c\u0438 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430\u043c\u0438.\u041d\u043e\u0430 \u041c\u0438\u0448 \u0434\u043e\u043d\u0435\u0441 \u043c\u0438\u0440\u0443 \u0442\u043e, \u0447\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0440\u0430\u0437\u043b\u0438\u0447\u0438\u043c\u044b\u0445 \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432 \u043d\u0430 PostgreSQL 8.3 \u043e\u043d \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0435\u0442 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432 4 \u0440\u0430\u0437\u0430 (\u0412 PostgreSQL 18 \u0432 3.x \u0440\u0430\u0437 \u0438\u043b\u0438, \u043a\u0430\u043a \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u043f\u0438\u0448\u0435\u0442 \u0410\u043d\u0434\u0440\u0435\u0439 \u041b\u0435\u043f\u0438\u0445\u043e\u0432\u00a0&#171;\u0441\u0432\u0435\u0440\u0445\u044d\u043a\u0441\u043f\u043e\u043d\u0435\u043d\u0446\u0438\u0430\u043b\u044c\u043d\u043e&#187;) \u0438 \u043f\u0440\u0438\u0432\u0435\u043b \u043f\u0440\u0438\u043c\u0435\u0440 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f 16 \u0442\u0430\u0431\u043b\u0438\u0446. \u0410 \u0434\u043b\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0441 19-21 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f\u043c\u0438, \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0437\u043c (\u0432\u043a\u043b\u044e\u0447\u0438\u0442\u044c GEQO),\u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0434\u043b\u0438\u043b\u043e\u0441\u044c \u0431\u043e\u043b\u0435\u0435, \u0447\u0435\u043c 600 \u0441\u0435\u043a\u0443\u043d\u0434 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u043e \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u043f\u043b\u0430\u043d\u0438\u0440\u0432\u0430\u043d\u0438\u044f \u0431\u043e\u043b\u0435\u0435 10 \u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438. \u041d\u043e\u0430 \u041c\u0438\u0448 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u0442\u0430\u043b\u043a\u0438\u0432\u0430\u043b\u0441\u044f \u0441 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0435\u0439, \u043a\u043e\u0433\u0434\u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u043e\u0442\u043b\u0438\u0447\u043d\u043e\u0435 \u043e\u0442\u00a01 \u0438\u043b\u0438 &#171;\u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0441\u0442\u044c&#187;, \u0434\u043b\u044f *_collapse_limit, \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0431\u044b \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c.\u0422\u043e\u043c \u041b\u0435\u0439\u043d \u0441\u043a\u0430\u0437\u0430\u043b, \u0447\u0442\u043e DBA \u043b\u044e\u0431\u044f\u0442 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e\u0441\u0442\u044c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u043e-\u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u0434\u043b\u044f join_collapse_limit \u0438 from_collapse_limit \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u044b \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u0435\u0434\u043e\u0442\u0432\u0440\u0430\u0442\u0438\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 GEQO. \u00a0\u0415\u0441\u043b\u0438 \u0443\u0431\u0440\u0430\u0442\u044c *_collapse_limit, \u0442\u043e \u043f\u043e\u0441\u044b\u043f\u044f\u0442\u0441\u044f \u0436\u0430\u043b\u043e\u0431\u044b, \u0447\u0442\u043e \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f, \u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0442\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e, \u0435\u0441\u043b\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435 \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c GEQO \u0438 \u0441\u043e\u0441\u043b\u0430\u043b\u0441\u044f \u043d\u0430 \u043d\u0435\u0434\u0430\u0432\u043d\u044e\u044e \u0436\u0430\u043b\u043e\u0431\u0443 \u0441 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435\u043c 17 \u0442\u0430\u0431\u043b\u0438\u0446.\u041c\u043d\u0435\u043d\u0438\u0435 \u0422\u043e\u043c\u0430 \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u043b \u041a\u0435\u0432\u0438\u043d \u0413\u0440\u0438\u0442\u0442\u043d\u0435\u0440 (\u043a\u0430\u043a \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u0435\u043b\u044c DBA \u0432 \u043e\u0431\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u0438), \u0447\u0442\u043e \u0433\u043b\u0430\u0432\u043d\u0430\u044f \u043f\u0440\u0438\u0447\u0438\u043d\u0430, \u043f\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043e\u043d \u0441\u0442\u0430\u0440\u0430\u0435\u0442\u0441\u044f \u0438\u0437\u0431\u0435\u0433\u0430\u0442\u044c GEQO, \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0437\u043d\u0430\u0435\u0442, GEQO \u043c\u043e\u0436\u0435\u0442 \u0440\u0435\u0434\u043a\u043e, \u043d\u043e \u043c\u0435\u0442\u043a\u043e, \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u0440\u0438\u0432\u043e\u0439 \u043f\u043b\u0430\u043d, \u0447\u0442\u043e \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043a \u0437\u0430\u0433\u0430\u0434\u043e\u0447\u043d\u044b\u043c \u0436\u0430\u043b\u043e\u0431\u0430\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439, \u0438 \u044d\u0442\u0438 \u0436\u0430\u043b\u043e\u0431\u044b \u043c\u043e\u0433\u0443\u0442 \u043e\u0442\u043d\u044f\u0442\u044c \u043c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043d\u0430 \u0440\u0430\u0437\u0431\u043e\u0440 \u043f\u0440\u0438\u0447\u0438\u043d.\u0410\u043d\u0434\u0440\u0435\u0430\u0441 \u0424\u0440\u043e\u0439\u043d\u0434 \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u043d\u0435\u0439 \u0438 \u0441\u043e\u0437\u0434\u0430\u043b \u0441\u043b\u043e\u0436\u043d\u044b\u0439 \u0442\u0435\u0441\u0442\u043a\u0435\u0439\u0441 \u0438\u0437 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0438 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b \u0432 \u0442\u043e\u043f\u0438\u043a\u0435. \u041b\u044e\u0431\u043e\u0439 \u043c\u043e\u0436\u0435\u0442 \u0435\u0433\u043e \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c. \u042f \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0451\u043b \u043d\u0430 18 \u0432\u0435\u0440\u0441\u0438\u0438 \u0442\u0435\u0441\u0442 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430:\\timing on \\\\SET SEARCH_PATH = test_data, test_view;SET geqo = off;SET join_collapse_limit = 11;&#8212; 2617.020 ms Memory: used=597053kB  allocated=599284kBSET join_collapse_limit = 12;&#8212; 3205.557 ms used=759366kB  allocated=763124kBSET join_collapse_limit = 13;&#8212; 3266.530 ms used=769482kB  allocated=771316kBSET join_collapse_limit = 14;&#8212; 7079.614 ms used=1090170kB  allocated=1091380kBSET join_collapse_limit = 15;&#8212; 15926.589 ms used=2179803kB  allocated=2181044kBSET join_collapse_limit = 16;&#8212; 13124.880 ms used=2210545kB  allocated=2213812kBSET join_collapse_limit = 17;&#8212; 19529.137 ms used=2793452kB  allocated=2796724kBSET join_collapse_limit = 18;&#8212; 63925.147 ms used=8861636kB  allocated=8869044kBSET join_collapse_limit = 19;&#8212; 56204.530 ms used=8861646kB  allocated=8869044kBSET join_collapse_limit = 20;&#8212; 85993.891 ms used=11677634kB  allocated=11679733kBSET geqo = off;SET join_collapse_limit = 21;&#8212; \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u0438.\u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043d\u0430 \u0442\u0435\u0441\u0442\u0435 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0424\u0440\u043e\u0439\u043d\u0434\u0430, \u043f\u0430\u043c\u044f\u0442\u044c \u0438 \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u043e\u0441\u044c \u0441\u043a\u0430\u0447\u043a\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a, \u0441 11\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u0430\u0441\u044c \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u043c \u043d\u0430 \u0432\u0440\u0435\u043c\u044f \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u043b \u043f\u043e\u0441\u043b\u0435 join_collapse_limit = 20. \u041d\u0435\u0445\u0432\u0430\u0442\u043a\u0430 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442, \u043a\u0430\u043a \u043f\u043e\u0434\u0432\u0438\u0441\u0430\u043d\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b (\u0438\u0437-\u0437\u0430 \u043a\u044d\u0448\u0435\u0439) \u0438 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u044f\u043a\u043e\u0431\u044b \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440 \u0441\u0438\u043b\u044c\u043d\u043e \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f.\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u0442\u0441\u044e\u0434\u0430 \u0438 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0447\u0438\u0441\u043b\u043e 20. \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u0441\u0442\u0430\u043b\u0438, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0438\u0437 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043f\u0440\u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u043c GEQO \u0441\u0438\u0441\u0442\u0441\u0435\u043c\u0430 \u0445\u043e\u0442\u044f \u0431\u044b \u043d\u0435 \u043f\u043e\u0434\u0432\u0438\u0441\u043d\u0435\u0442 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0445\u0432\u0430\u0442\u0438\u0442. \u0422\u043e \u0435\u0441\u0442\u044c *_collapse_limit = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430\u044f \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u0447\u0438\u0441\u0442\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u0449\u0438\u0442\u0438\u0442\u044c\u0441\u044f \u043e\u0442 geqo = off.\u041d\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0438 \u041a\u0435\u0432\u0438\u043d\u0430 \u0434\u043b\u044f \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0445 \u0431\u0438\u0437\u043d\u0435\u0441-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0418\u043d\u0442\u0435\u0440\u0435\u0441\u0435\u043d \u0433\u0440\u0430\u043d\u0438\u0447\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0439 \u041d\u043e\u0430 \u041c\u0438\u0448. \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u0434\u043b\u044f join_colapse_limit \u0441\u043e \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0440\u0430\u0437\u043b\u0438\u0447\u0438\u043c\u044b\u043c\u0438 \u0441\u0442\u043e\u043b\u0431\u0430\u043c\u0438:\\timing on \\\\SET geqo = on;SET geqo_threshold = 16;SET join_collapse_limit = 16;EXPLAIN (analyze, memory, settings) with t as (select 1 a)select 1 from t t0 natural join t t1 natural join t t2 natural join tt3 natural join t t4 natural join t t5 natural join t t6 natural join t t7natural join t t8 natural join t t9 natural join t t10 natural join t t11natural join t t12 natural join t t13 natural join t t14;Settings: geqo_threshold = &#8217;15&#8217;, join_collapse_limit = &#8217;15&#8217; Planning:   Memory: used=235kB  allocated=256kB Planning Time: 33.668 ms Execution Time: 0.328 msSettings: geqo_threshold = &#8217;15&#8217;, join_collapse_limit = &#8217;14&#8217; Planning:   Memory: used=5155822kB  allocated=5162241kB Planning Time: 18779.568 ms Execution Time: 0.410 msSettings: geqo_threshold = &#8217;15&#8217;, join_collapse_limit = &#8217;13&#8217; Planning:   Memory: used=1680916kB  allocated=1688193kB Planning Time: 5986.123 ms Execution Time: 0.409 msSettings: geqo_threshold = &#8217;15&#8217;, join_collapse_limit = &#8217;12&#8217; Planning:   Memory: used=546392kB  allocated=549153kB Planning Time: 1937.615 ms Execution Time: 0.395 ms\u0422\u043e \u0435\u0441\u0442\u044c \u0445\u0443\u0434\u0448\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043a\u043e\u0433\u0434\u0430 *_collapse_limit \u043c\u0435\u043d\u044c\u0448\u0435 geqo_threshold \u043d\u0430 \u0435\u0434\u0438\u043d\u0438\u0446\u0443.\u041f\u0440\u0438 geqo_threshold = &#8217;16&#8217;, join_collapse_limit = &#8217;15&#8217; \u0432\u044b\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f 15\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438, \u0447\u0442\u043e \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043d\u043e\u0433\u043e.Planning Time: 41241.285 ms Memory: used=15761345kB\u0420\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f *_collapse_limit = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430. \u0415\u0441\u043b\u0438 \u043d\u0435 \u043e\u0442\u043a\u043b\u044e\u0447\u0430\u0442\u044c GEQO \u0438 \u043d\u0435 \u043c\u0435\u043d\u044f\u0442\u044c geqo_threshold, \u0442\u043e \u0435\u0433\u043e \u0434\u0430\u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c 30, 40. \u041d\u0430 \u044d\u0442\u043e \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u0442\u043e\u0440\u043e\u0439 \u0433\u0440\u0430\u0444\u0438\u043a \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 \u041f\u0430\u0432\u043b\u0430 \u0422\u043e\u043b\u043c\u0430\u0447\u0451\u0432\u0430. \u0425\u043e\u0440\u043e\u0448\u0438\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0442\u0430\u043a\u0436\u0435 \u0435\u0441\u0442\u044c \u0432 \u0441\u0442\u0430\u0442\u044c\u0435.\u041e\u0441\u0442\u0430\u043b\u0441\u044f \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u0432\u043e\u043f\u0440\u043e\u0441 (\u043a\u0442\u043e \u0443\u0431\u0438\u043b \u043c\u0438\u0441\u0442\u0435\u0440\u0430 \u041d\u043e\u043b\u0435\u0441\u0442\u0440\u043e): \u043d\u0443\u0436\u043d\u043e \u043b\u0438 \u0441\u0442\u0430\u0432\u0438\u0442\u044c *_collapse_limit \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c geqo_threshold, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 12. \u0414\u0430, \u043d\u0443\u0436\u043d\u043e. \u0412 1\u0421 \u0431\u044b\u043b\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430, \u043a\u043e\u0433\u0434\u0430 \u0432 \u043a\u043e\u043d\u0435\u0446 \u00a0\u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0447\u0438\u0441\u043b\u043e\u043c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0434\u043e\u0431\u0430\u0432\u0430\u043b\u044f\u043b\u0441\u044f &#171;ANDt1.col1 IN ( VALUES(..&#187;. \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043e\u043f\u0438\u0441\u0430\u043d\u0430 \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440\u0430 \u0421\u0438\u043c\u043e\u043d\u043e\u0432\u0430. \u0410\u043d\u0434\u0440\u0435\u0439 \u041b\u0435\u043f\u0438\u0445\u043e\u0432 \u0438 \u0410\u043b\u0451\u043d\u0430 \u0420\u044b\u0431\u0430\u043a\u0438\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u043f\u0430\u0442\u0447 (\u0440\u0435\u0432\u044c\u044e\u0432\u0435\u0440\u044b \u0418\u0432\u0430\u043d \u041a\u0443\u0448\u043d\u0430\u0440\u0435\u043d\u043a\u043e \u0438 \u0410\u043b\u0435\u043a\u0441\u0430\u043d\u0434\u0440 \u041a\u043e\u0440\u043e\u0442\u043a\u043e\u0432), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0447\u0440\u0435\u0437\u0432\u044b\u0447\u0430\u0439\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0431\u044b\u043b \u0437\u0430\u043a\u043e\u043c\u043c\u0438\u0447\u0435\u043d \u0422\u043e\u043c\u043e\u043c \u041b\u0435\u0439\u043d\u043e\u043c. \u042d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0443\u0448\u043b\u0430, \u043d\u043e *_collapse_limit \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0435 \u0432 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0431\u043e\u043b\u044c\u0448\u0435\u0435 geqo_threshold, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0443 \u0441\u043e\u0435\u0434\u0438\u043d\u0438\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u0438\u0437 \u043d\u0430\u0447\u0430\u043b\u0430 \u0438 \u043a\u043e\u043d\u0446\u0430 \u0441\u043f\u0438\u0441\u043a\u0430 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0439 \u0438\u043b\u0438 \u043f\u0440\u0435\u0434\u0438\u043a\u0430\u0442\u043e\u0432. \u0413\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u043b\u0438 1\u0421 \u0441\u0435\u0439\u0447\u0430\u0441 \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0433\u0434\u0435 \u044d\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u044f \u043d\u0435 \u0437\u043d\u0430\u044e, \u043d\u043e \u0434\u043e \u043f\u0430\u0442\u0447\u0430 \u043d\u0430 VALUES \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b. \u0414\u0430\u0435\u0442 \u043b\u0438 \u043c\u0438\u043d\u0443\u0441\u044b \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 *_collapse_limit \u0432 \u0447\u0443\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0447\u0435\u043c 20? \u041f\u043e \u0433\u0440\u0430\u0444\u0438\u043a\u0443 \u0438\u0437 \u0441\u0442\u0430\u0442\u044c\u0438 \u041f\u0430\u0432\u043b\u0430 \u0422\u043e\u043b\u043c\u0430\u0447\u0435\u0432\u0430 \u043f\u043e\u0447\u0442\u0438 \u043d\u0435\u0442. \u041f\u043b\u0430\u043d\u044b \u043d\u0435 \u0443\u043b\u0443\u0447\u0448\u0438\u0442 (\u0435\u0441\u043b\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435\u0442 \u043e\u0448\u0438\u0431\u043e\u043a \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0449\u0438\u043a\u0430).\u042f \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0451\u043b \u043d\u0430 18 \u0432\u0435\u0440\u0441\u0438\u0438 \u0442\u0435\u0441\u0442 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430:\\timing on \\\\SET SEARCH_PATH = test_data, test_view;SET geqo = off;SET join_collapse_limit = 11;&#8212; 2617.020 ms Memory: used=597053kB  allocated=599284kBSET join_collapse_limit = 12;&#8212; 3205.557 ms used=759366kB  allocated=763124kBSET join_collapse_limit = 13;&#8212; 3266.530 ms used=769482kB  allocated=771316kBSET join_collapse_limit = 14;&#8212; 7079.614 ms used=1090170kB  allocated=1091380kBSET join_collapse_limit = 15;&#8212; 15926.589 ms used=2179803kB  allocated=2181044kBSET join_collapse_limit = 16;&#8212; 13124.880 ms used=2210545kB  allocated=2213812kBSET join_collapse_limit = 17;&#8212; 19529.137 ms used=2793452kB  allocated=2796724kBSET join_collapse_limit = 18;&#8212; 63925.147 ms used=8861636kB  allocated=8869044kBSET join_collapse_limit = 19;&#8212; 56204.530 ms used=8861646kB  allocated=8869044kBSET join_collapse_limit = 20;&#8212; 85993.891 ms used=11677634kB  allocated=11679733kBSET geqo = off;SET join_collapse_limit = 21;&#8212; \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u0438\u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043d\u0430 \u0442\u0435\u0441\u0442\u0435 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0424\u0440\u043e\u0439\u043d\u0434\u0430, \u043f\u0430\u043c\u044f\u0442\u044c \u0438 \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u043e\u0441\u044c \u0441\u043a\u0430\u0447\u043a\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0430\u0447\u043e\u043a, \u0441 11\u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u0430\u0441\u044c \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u043c \u043d\u0430 \u0432\u0440\u0435\u043c\u044f \u043f\u043b\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u043b \u043f\u043e\u0441\u043b\u0435 join_collapse_limit = 20. \u041d\u0435\u0445\u0432\u0430\u0442\u043a\u0430 \u043f\u0430\u043c\u044f\u0442\u0438 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442, \u043a\u0430\u043a \u043f\u043e\u0434\u0432\u0438\u0441\u0430\u043d\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b (\u0438\u0437-\u0437\u0430 \u043a\u044d\u0448\u0435\u0439) \u0438 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u044f\u043a\u043e\u0431\u044b \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440 \u0441\u0438\u043b\u044c\u043d\u043e \u0433\u0440\u0443\u0437\u0438\u0442\u0441\u044f.\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u0442\u0441\u044e\u0434\u0430 \u0438 \u0432\u0437\u044f\u043b\u043e\u0441\u044c \u0447\u0438\u0441\u043b\u043e 20. \u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u0441\u0442\u0430\u043b\u0438, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0438\u0437 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043f\u0440\u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u043c GEQO \u0441\u0438\u0441\u0442\u0441\u0435\u043c\u0430 \u0445\u043e\u0442\u044f \u0431\u044b \u043d\u0435 \u043f\u043e\u0434\u0432\u0438\u0441\u043d\u0435\u0442 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0445\u0432\u0430\u0442\u0438\u0442. \u0422\u043e \u0435\u0441\u0442\u044c *_collapse_limit = 20 \u0440\u0430\u0437\u0443\u043c\u043d\u0430\u044f \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u044f \u0447\u0438\u0441\u0442\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u0449\u0438\u0442\u0438\u0442\u044c\u0441\u044f \u043e\u0442 geqo = off.\u041d\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0410\u043d\u0434\u0440\u0435\u0430\u0441\u0430 \u0438 \u041a\u0435\u0432\u0438\u043d\u0430 \u0434\u043b\u044f \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u0445 \u0431\u0438\u0437\u043d\u0435\u0441-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0418\u043d\u0442\u0435\u0440\u0435\u0441\u0435\u043d \u0433\u0440\u0430\u043d\u0438\u0447\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439, \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0439 \u041d\u043e\u0430 \u041c\u0438\u0448. \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u0434\u043b\u044f join_colapse_limit \u0441\u043e \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0435\u0440\u0430\u0437\u043b\u0438\u0447\u0438\u043c\u044b\u043c\u0438 \u0441\u0442\u043e\u043b\u0431\u0430\u043c\u0438:\\timing on \\\\SET geqo = on;SET geqo_threshold = 16;SET join_collapse_limit = 16;EXPLAIN (analyze, memory, settings) with t as (select 1 a)select 1 from t t0 natural join t t1 natural join t t2 natural join tt3 natural join t t4 natural join t t5 natural join t t6 natural join t t7natural join t t8 natural join t &#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-480830","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/480830","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=480830"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/480830\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=480830"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=480830"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=480830"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}