{"id":201474,"date":"2013-11-18T07:13:03","date_gmt":"2013-11-18T03:13:03","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=201474"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=201474","title":{"rendered":"<span class=\"post_title\">\u0420\u0438\u0441\u0443\u0435\u043c \u043a\u0430\u0440\u0442\u0443 \u043e\u0434\u043d\u0438\u043c select&#8217;\u043e\u043c \u0438\u043b\u0438 \u043e \u043f\u043e\u043b\u044c\u0437\u0435 \u043c\u043d\u043e\u0433\u043e\u0442\u0430\u0431\u043b\u0438\u0447\u043d\u044b\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432<\/span>"},"content":{"rendered":"<div class=\"content html_format\">   \t<img decoding=\"async\" src=\"http:\/\/habr.habrastorage.org\/post_images\/cf2\/f0a\/52b\/cf2f0a52b2b81dea98931ffeab19466e.png\" alt=\"image\"\/><br \/>  \u0414\u0430\u043d\u043d\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0430 \u0432 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435 \u0441\u0435\u0440\u0438\u0438, \u043f\u043e\u0432\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u043e \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e web map \u0441\u0435\u0440\u0432\u0435\u0440\u0430. <a href=\"http:\/\/habrahabr.ru\/post\/196682\/\">\u0420\u0430\u043d\u0435\u0435<\/a> \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u043b\u043e\u0441\u044c \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u0432 \u043d\u0435\u043c \u0443\u0441\u0442\u0440\u043e\u0435\u043d\u044b \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0430 \u0442\u0430\u043a \u0436\u0435 \u043e \u0442\u043e\u043c, <a href=\"http:\/\/habrahabr.ru\/post\/200642\/\">\u043a\u0430\u043a<\/a> \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0442\u0430\u043a \u0432\u043e\u0442 \u0432\u0437\u044f\u0442\u044c \u0438 \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0441\u043b\u043e\u0439. \u0421\u0435\u0439\u0447\u0430\u0441 \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u044d\u0442\u043e \u0447\u0443\u0442\u044c \u0438\u0437\u044f\u0449\u043d\u0435\u0435.<br \/>  <a name=\"habracut\"><\/a><br \/>  \u0412 \u0442\u043e\u043c, \u0447\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u043e\u0434\u043d\u0438\u043c \u0441\u043b\u043e\u0435\u043c \u043c\u044b \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c, \u043d\u043e \u0432\u0435\u0434\u044c \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441\u043b\u043e\u0451\u0432 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0434\u0435\u0441\u044f\u0442\u043a\u0438, \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 \u043d\u0438\u0445 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u0434\u0435\u043b\u0430\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u0432 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435, \u0434\u0430\u0436\u0435, \u0435\u0441\u043b\u0438 \u0432 \u043f\u043e\u0438\u0441\u043a\u043e\u0432\u044b\u0439 \u044d\u043a\u0441\u0442\u0435\u043d\u0442 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u043f\u0430\u043b\u043e\u2026 \u041d\u0435\u043b\u044c\u0437\u044f \u043b\u0438 \u043a\u0430\u043a-\u0442\u043e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u0442\u0438\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0439 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0438 \u0438\u0437\u0431\u0430\u0432\u0438\u0442\u044c\u0441\u044f \u043e\u0442 \u0437\u0430\u0432\u0435\u0434\u043e\u043c\u043e \u0431\u0435\u0441\u043f\u043e\u043b\u0435\u0437\u043d\u044b\u0445 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439?<\/p>\n<h4><b>\u0418\u043d\u0434\u0435\u043a\u0441\u0430\u0446\u0438\u044f<\/b><\/h4>\n<p>  \u041c\u043e\u0436\u043d\u043e, \u043e\u0442\u0447\u0435\u0433\u043e \u0436\u0435 \u043d\u0435\u0442. \u041d\u043e \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0430\u043c \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0435\u0434\u0438\u043d\u044b\u0439 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0445 \u0441\u043b\u043e\u0451\u0432. \u0412\u0441\u043f\u043e\u043c\u043d\u0438\u043c, \u043a\u0430\u043a \u0443\u0441\u0442\u0440\u043e\u0435\u043d\u044b \u043d\u0430\u0448\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b:  <\/p>\n<ul>\n<li>\u041f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e \u0441\u043b\u043e\u044f \u0434\u0435\u043b\u0438\u0442\u0441\u044f \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u043e\u0439 \u0440\u0435\u0448\u0435\u0442\u043a\u043e\u0439 \u043d\u0430 \u0431\u043b\u043e\u043a\u0438<\/li>\n<li>\u0412\u0441\u0435 \u0431\u043b\u043e\u043a\u0438 \u043d\u0443\u043c\u0435\u0440\u0443\u044e\u0442\u0441\u044f<\/li>\n<li>\u041a\u0430\u0436\u0434\u043e\u043c\u0443 \u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u0443\u0435\u043c\u043e\u043c\u0443 \u043e\u0431\u044a\u0435\u043a\u0442\u0443 \u043f\u0440\u0438\u0441\u0432\u0430\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u0434\u0438\u043d \u0438\u043b\u0438 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u043e\u043c\u0435\u0440\u043e\u0432 \u0431\u043b\u043e\u043a\u043e\u0432, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043e\u043d \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d<\/li>\n<li>\u041f\u0440\u0438 \u043f\u043e\u0438\u0441\u043a\u0435 \u044d\u043a\u0441\u0442\u0435\u043d\u0442 \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0440\u0430\u0441\u0449\u0435\u043f\u043b\u044f\u0435\u0442\u0441\u044f \u043d\u0430 \u0431\u043b\u043e\u043a\u0438 \u0438 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0431\u043b\u043e\u043a\u0430 \u0438\u043b\u0438 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u043e\u0439 \u0446\u0435\u043f\u043e\u0447\u043a\u0438 \u0431\u043b\u043e\u043a\u043e\u0432 \u0438\u0437 \u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e \u0446\u0435\u043b\u043e\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u0434\u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u0432\u0441\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u043c \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u0430\u0442<\/li>\n<\/ul>\n<p>  \u041d\u0443 \u0447\u0442\u043e \u0436\u0435, \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0435\u0434\u0438\u043d\u043e\u0433\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u0434\u0435\u043b\u0438\u0442\u044c \u0432\u0441\u0435 \u0441\u043b\u043e\u0438 \u043e\u0434\u043d\u043e\u0439 \u0440\u0435\u0448\u0435\u0442\u043a\u043e\u0439, \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u043d\u0443\u043c\u0435\u0440\u043e\u0432\u0430\u0442\u044c \u0431\u043b\u043e\u043a\u0438 \u0438 \u043a\u0440\u043e\u043c\u0435 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u0430 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u0445\u0440\u0430\u043d\u0438\u0442\u044c \u0432 \u0438\u043d\u0434\u0435\u043a\u0441\u0435 \u0435\u0449\u0435 \u0438 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 \u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u0418\u0442\u0430\u043a:  <\/p>\n<ul>\n<li>\u0422\u0440\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043a\u0430\u043a \u0438 \u0440\u0430\u043d\u044c\u0448\u0435 \u0431\u0443\u0434\u0435\u043c \u043d\u0430 shape \u0434\u0430\u043d\u043d\u044b\u0445, \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0445 \u0438\u0437 <a href=\"http:\/\/gis-lab.info\/qa\/osmshp.html\">OSM Russia<\/a>.<\/li>\n<li>\u0412\u043e\u0437\u044c\u043c\u0435\u043c 4 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0430\u0441\u0435\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u043b\u043e\u044f \u2013 \u0432\u043e\u0434\u043e\u0435\u043c\u044b, \u043b\u0435\u0441\u0430, \u0437\u0434\u0430\u043d\u0438\u044f \u0438 \u0434\u043e\u0440\u043e\u0433\u0438.<\/li>\n<li>\u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0421\u0423\u0411\u0414 \u043a\u0430\u043a \u0438 \u0440\u0430\u043d\u044c\u0448\u0435 \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c OpenSource \u0440\u0435\u0434\u0430\u043a\u0446\u0438\u044e <a href=\"http:\/\/virtuoso.openlinksw.com\/dataspace\/doc\/dav\/wiki\/Main\/\">OpenLink Virtuoso<\/a>, \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u0443\u044e Win_x64 \u0441\u0431\u043e\u0440\u043a\u0443 \u0432\u0435\u0440\u0441\u0438\u0438 7.0.0, \u0432\u0437\u044f\u0442\u0443\u044e \u0441 \u0441\u0430\u0439\u0442\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430.<\/li>\n<li>\u0414\u043b\u044f \u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u043d\u0430 <a href=\"http:\/\/en.wikipedia.org\/wiki\/GD_Graphics_Library\">GD<\/a> \u0438 \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0439 \u0440\u0430\u043d\u0435\u0435 C \u043f\u043b\u0430\u0433\u0438\u043d, \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u044e\u0449\u0438\u0439 \u043d\u0430\u0431\u043e\u0440 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 PL\/SQL.<\/li>\n<li>\u042d\u043a\u0441\u0442\u0435\u043d\u0442 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432\u043e\u0437\u044c\u043c\u0435\u043c: xmin=-180, ymin=35, xmax=180, ymax=85 \u0433\u0440\u0430\u0434\u0443\u0441\u043e\u0432.<\/li>\n<li>\u0420\u0430\u0437\u043e\u0431\u044c\u0435\u043c \u044d\u0442\u043e\u0442 \u044d\u043a\u0441\u0442\u0435\u043d\u0442 \u043d\u0430 \u0431\u043b\u043e\u043a\u0438 \u043f\u043e 0.1 \u00b0 \u043f\u043e \u0448\u0438\u0440\u043e\u0442\u0435 \u0438 \u0434\u043e\u043b\u0433\u043e\u0442\u0435. \u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0440\u0435\u0448\u0435\u0442\u043a\u0443 \u0438\u0437 3600\u0425500 \u0431\u043b\u043e\u043a\u043e\u0432. 0.1\u00b0 \u2014 \u044d\u0442\u043e \u043e\u043a\u043e\u043b\u043e 11 \u043a\u043c, \u043c\u043d\u043e\u0433\u043e\u0432\u0430\u0442\u043e \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u0434\u043e\u043c\u043e\u0432, \u043d\u043e \u043d\u0430\u0448\u0430 \u0446\u0435\u043b\u044c \u0432 \u0434\u0430\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 \u043d\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0432 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0445 \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u0445, \u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0430 \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u0438. <\/li>\n<li>\u0417\u0430\u0433\u0440\u0443\u0437\u0438\u043c \u0441\u043b\u043e\u0438 \u0432 \u0421\u0423\u0411\u0414 \u0442\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0438 \u0440\u0430\u043d\u044c\u0448\u0435:<br \/> \n<ul>\n<li>vegetation-polygon.shp: 657673 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 2&#8242; 4&#187;<\/li>\n<li>water-polygon.shp: 380868 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 1&#8242; 22&#187;<\/li>\n<li>building-polygon.shp: 5326421 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 15&#8242; 42&#187;<\/li>\n<li>highway-line.shp: 2599083 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 7&#8242; 56&#187;<\/li>\n<\/ul>\n<\/li>\n<li>\u0422\u0435\u043f\u0435\u0440\u044c \u0435\u0441\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 (Ex: \u00abxxx\u00bb.\u00abYYY\u00bb.\u00abwater-polygon\u00bb) \u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u043c\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 (Ex: \u00abxxx\u00bb.\u00abYYY\u00bb.\u00abwater-polygon__spx\u00bb). \u041f\u043e\u043b\u044c\u0437\u0443\u044f\u0441\u044c \u0442\u0435\u043c, \u0447\u0442\u043e \u0432\u0441\u0435 \u043e\u043d\u0438 \u0441\u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u044b \u0441 \u0435\u0434\u0438\u043d\u044b\u043c\u0438 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438, \u0441\u043e\u043b\u044c\u0435\u043c \u0438\u0445 \u0432 \u0435\u0434\u0438\u043d\u043e\u043c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435<br \/> \n<pre><code class=\"sql\">registry_set ('__spx_startx', '-180'); registry_set ('__spx_starty', '35'); registry_set ('__spx_nx', '3600'); registry_set ('__spx_ny', '500'); registry_set ('__spx_stepx', '0.1'); registry_set ('__spx_stepy', '0.1'); drop table &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot;; create table &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot; (  \t&quot;node_&quot; integer, &quot;tab_&quot; integer, &quot;oid_&quot; integer, \tprimary key (&quot;node_&quot;, &quot;tab_&quot;, &quot;oid_&quot;)); create procedure mp_total_spx () {   for select &quot;node_&quot;, &quot;oid_&quot; from &quot;xxx&quot;.&quot;YYY&quot;.&quot;water-polygon__spx&quot; do   {     insert into &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot; (&quot;oid_&quot;,&quot;tab_&quot;,&quot;node_&quot;)        values (&quot;oid_&quot;, 1, &quot;node_&quot;);     commit work;   }   for select &quot;node_&quot;, &quot;oid_&quot; from &quot;xxx&quot;.&quot;YYY&quot;.&quot;vegetation-polygon__spx&quot; do   {     insert into &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot; (&quot;oid_&quot;,&quot;tab_&quot;,&quot;node_&quot;)        values (&quot;oid_&quot;, 2, &quot;node_&quot;);     commit work;   }   for select &quot;node_&quot;, &quot;oid_&quot; from &quot;xxx&quot;.&quot;YYY&quot;.&quot;highway-line__spx&quot; do   {     insert into &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot; (&quot;oid_&quot;,&quot;tab_&quot;,&quot;node_&quot;)        values (&quot;oid_&quot;, 3, &quot;node_&quot;);     commit work;   }   for select &quot;node_&quot;, &quot;oid_&quot; from &quot;xxx&quot;.&quot;YYY&quot;.&quot;building-polygon__spx&quot; do   {     insert into &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot; (&quot;oid_&quot;,&quot;tab_&quot;,&quot;node_&quot;)        values (&quot;oid_&quot;, 4, &quot;node_&quot;);     commit work;   } }; mp_total_spx (); <\/code><\/pre>\n<p>\u0418\u0437\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u043e\u0431\u0449\u0435\u0433\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 2&#8217;16&#187;. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043a\u0443\u0440\u0441\u043e\u0440\u043e\u0432 \u0432\u043c\u0435\u0441\u0442\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u0438 (insert\u2026 select &#8230;) \u0432\u044b\u0437\u0432\u0430\u043d\u043e \u0442\u0435\u043c, \u0447\u0442\u043e \u0432 OpenSource-\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 \u0435\u0441\u0442\u044c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0432 50\u043c\u0431 \u043d\u0430 \u0440\u0430\u0437\u043c\u0435\u0440 \u043b\u043e\u0433\u0430 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438 \u0432 \u0436\u0443\u0440\u043d\u0430\u043b\u0435. \u0414\u0430\u043d\u043d\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043b\u0435\u0433\u043a\u043e \u0443\u0441\u0442\u0440\u0430\u043d\u0438\u0442\u044c \u043f\u0435\u0440\u0435\u0441\u0431\u043e\u0440\u043a\u043e\u0439, \u043d\u043e \u044d\u0442\u043e \u0443\u0436\u0435 \u0434\u0440\u0443\u0433\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f.   <\/li>\n<li>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0442\u043e\u043c\u0443, \u043a\u0430\u043a \u043c\u044b \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u043b\u0438 \u0440\u0430\u043d\u044c\u0448\u0435<br \/> \n<pre><code class=\"sql\">create procedure &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx_enum_items_in_box&quot; ( \tin minx double precision,  \tin miny double precision,  \tin maxx double precision,  \tin maxy double precision) {   declare nx, ny integer;   nx := atoi (registry_get ('__spx_nx'));   ny := atoi (registry_get ('__spx_ny'));   declare startx, starty double precision;   startx := atof (registry_get ('__spx_startx'));   starty := atof (registry_get ('__spx_starty'));   declare stepx, stepy double precision;   stepx := atof (registry_get ('__spx_stepx'));   stepy := atof (registry_get ('__spx_stepy'));   declare sx, sy, fx, fy integer;   sx := cast (floor ((minx - startx)\/stepx) as integer);   fx := cast (floor ((maxx - startx)\/stepx) as integer);   sy := cast (floor ((miny - starty)\/stepy) as integer);   fy := cast (floor ((maxy - starty)\/stepy) as integer);   declare ress any;   ress := vector(dict_new (), dict_new (), dict_new (), dict_new ());   for (declare iy integer, iy := sy; iy &lt;= fy; iy := iy + 1)  {     declare ixf, ixt integer;     ixf := nx * iy + sx;     ixt := nx * iy + fx;     for select &quot;node_&quot;, &quot;tab_&quot;, &quot;oid_&quot; from &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx&quot;          where &quot;node_&quot; &gt;= ixf and &quot;node_&quot; &lt;= ixt do  {       dict_put (ress[&quot;tab_&quot; - 1], &quot;oid_&quot;, 0);     }   }   result_names('oid', 'tab');   declare ix integer;   for (ix := 0; ix &lt; 4; ix := ix + 1)  {     declare arr any;     arr := dict_list_keys (ress[ix], 1);     gvector_digit_sort (arr, 1, 0, 1);     foreach (integer oid in arr) do     { result (oid, ix + 1); }   } };  create procedure view &quot;xxx&quot;.&quot;YYY&quot;.&quot;v_total__spx_enum_items_in_box&quot; as &quot;xxx&quot;.&quot;YYY&quot;.&quot;total__spx_enum_items_in_box&quot; (minx, miny, maxx, maxy) (&quot;oid&quot; integer, &quot;tab&quot; integer);  <\/code><\/pre>\n<p>  <\/li>\n<li>\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u044b:\n<pre><code class=\"sql\">select count(*) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;v_total__spx_enum_items_in_box&quot; as a where a.minx = 82.963 and a.miny = 54.9866  and a.maxx = 82.98997 and a.maxy = 55.0133; select count(*) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;v_vegetation-polygon_spx_enum_items_in_box&quot; ... select count(*) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;v_water-polygon_spx_enum_items_in_box&quot; ... select count(*) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;v_building-polygon_spx_enum_items_in_box&quot; ... select count(*) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;v_highway-line_spx_enum_items_in_box&quot; ... <\/code><\/pre>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u0435\u0440\u043d\u0443\u043b 29158, \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435: 941 + 33 + 20131 + 8053. \u0421\u043e\u0432\u043f\u0430\u0434\u0430\u0435\u0442.<\/li>\n<\/ul>\n<p>  <\/p>\n<h4><b>\u0417\u0430\u043c\u0435\u0440\u044f\u0435\u043c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441\u0430.<\/b><\/h4>\n<p>  \u0411\u0443\u0434\u0435\u043c \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0441\u0435\u0440\u0438\u0438 \u0438\u0437 10000 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u0445 \u043f\u043e\u0438\u0441\u043a\u043e\u0432 \u0432 \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u0435 [35&#8230;45,50&#8230;60]\u00b0 \u043d\u0430 \u043e\u0431\u0449\u0435\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435 \u0438 \u0441\u0442\u0430\u0440\u044b\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c. \u0412\u0441\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0432 \u043e\u0434\u043d\u043e\u043c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0438 \u0442.\u0435. \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043d\u0430 \u043e\u0434\u043d\u043e \u044f\u0434\u0440\u043e.  <\/p>\n<table>\n<tr>\n<th>\u0420\u0430\u0437\u043c\u0435\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u0430<\/th>\n<th>\u0412\u0440\u0435\u043c\u044f \u0432 \u0435\u0434\u0438\u043d\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435<\/th>\n<th>\u0412\u0440\u0435\u043c\u044f \u043f\u043e-\u0441\u0442\u0430\u0440\u043e\u043c\u0443<\/th>\n<\/tr>\n<tr>\n<td>0.01\u00b0<\/td>\n<td>7&#8217;35&#187;<\/td>\n<td>8&#8217;26&#187;<\/td>\n<\/tr>\n<tr>\n<td>0.1\u00b0<\/td>\n<td>8&#8217;25&#187;<\/td>\n<td>9&#8217;20&#187;<\/td>\n<\/tr>\n<tr>\n<td>0.5\u00b0<\/td>\n<td>15&#8217;11&#187;<\/td>\n<td>16&#8217;7&#187;<\/td>\n<\/tr>\n<\/table>\n<p> <b>\u0412\u044b\u0432\u043e\u0434<\/b>: \u0434\u0430, \u0435\u0434\u0438\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0431\u044b\u0441\u0442\u0440\u0435\u0435, \u043d\u043e \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043d\u0435 \u043f\u043e\u0440\u0430\u0436\u0430\u0435\u0442 \u0432\u043e\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435. \u0421 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u0432\u0441\u0435 4 \u043d\u0430\u0448\u0438\u0445 \u0441\u043b\u043e\u044f \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043b\u043e\u0442\u043d\u043e \u0437\u0430\u0441\u0435\u043b\u0435\u043d\u044b, \u043e\u043f\u044f\u0442\u044c \u0436\u0435 \u043d\u0435\u043c\u0430\u043b\u043e\u0432\u0430\u0436\u043d\u043e, \u0447\u0442\u043e \u043e\u0431\u044a\u0435\u043c \u0434\u0430\u043d\u043d\u044b\u0445 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0432\u0441\u0435 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u0430 \u0435\u0434\u0438\u043d\u043e\u0433\u043e \u043f\u043e\u0438\u0441\u043a\u0430 \u0432\u0441\u0442\u0430\u043b\u0438 \u0432\u043e \u0432\u0435\u0441\u044c \u0440\u043e\u0441\u0442. \u0421 \u0442\u0440\u0435\u0442\u044c\u0435\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u044d\u0442\u043e \u0436\u0438\u0432\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435, \u043a\u0430\u043a \u043e\u043d\u0438 \u0435\u0441\u0442\u044c.<\/p>\n<h4><b>\u0420\u0438\u0441\u0443\u0435\u043c \u043a\u0430\u0440\u0442\u0443<\/b><\/h4>\n<p>  \u041f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u043d\u0430\u0440\u0438\u0441\u0443\u0435\u043c \u0435\u0435 <b>\u0441\u0442\u0430\u0440\u044b\u043c \u043f\u0443\u0442\u0435\u043c<\/b>, \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u043b\u043e \u0441 \u0447\u0435\u043c \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c.  <\/p>\n<pre><code class=\"sql\">create procedure mk_test_gif(  \tin cminx double precision,  \tin cminy double precision,  \tin cmaxx double precision,  \tin cmaxy double precision) {   declare img any;   img := img_create (512, 512, cminx, cminy, cmaxx, cmaxy, 1);   declare cl integer;   declare bg integer;   {     cl := img_alloc_color (img, 0, 0, 255);     bg := img_alloc_color (img, 0, 0, 255);     whenever not found goto nf;     for select blob_to_string(Shape) as data from        xxx.YYY.&quot;water-polygon&quot; as x, xxx.YYY.&quot;v_water-polygon_spx_enum_items_in_box&quot; as a     where a.minx = cminx and a.miny = cminy and a.maxx = cmaxx and a.maxy = cmaxy        and x.&quot;_OBJECTID_&quot; = a.oid       and x.maxx_ &gt;= cminx and x.minx_ &lt;= cmaxx       and x.maxy_ &gt;= cminy and x.miny_ &lt;= cmaxy     do  { img_draw_polygone (img, data, cl, bg); } nf:; ...   \u0434\u043b\u044f \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0442\u0430\u0431\u043b\u0438\u0446 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u043e \u0436\u0435, \u0434\u043e\u0440\u043e\u0433\u0438 \u0440\u0438\u0441\u0443\u044e\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 img_draw_polyline. ...   }   declare ptr integer;   ptr := img_tostr (img);   img_destroy (img);   declare image any;   image := img_fromptr(ptr);   string_to_file('test.gif', image, -2);                            return; }; mk_test_gif(35., 50., 45., 60.); <\/code><\/pre>\n<p> \u0420\u0430\u0431\u043e\u0442\u0430 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 17.2 \u0441\u0435\u043a.<\/p>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043a\u0430\u043a \u0438 \u043e\u0431\u0435\u0449\u0430\u043d\u043e, \u043e\u0434\u043d\u0438\u043c \u0441\u0435\u043b\u0435\u043a\u0442\u043e\u043c. \u041f\u0435\u0440\u0432\u043e\u0435, \u0447\u0442\u043e \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442 \u0432 \u0433\u043e\u043b\u043e\u0432\u0443, <br \/>  <b>\u0430\u0433\u0440\u0435\u0433\u0430\u0442\u044b<\/b>.<br \/>  \u0410\u0433\u0440\u0435\u0433\u0430\u0442 \u2014 \u044d\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442, \u0441\u043e\u0437\u0434\u0430\u044e\u0449\u0438\u0439\u0441\u044f \u043f\u0440\u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u0438\u0438 \u043a\u0443\u0440\u0441\u043e\u0440\u0430, \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0449\u0438\u0439\u0441\u044f \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430 \u0438 \u0444\u0438\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u044e\u0449\u0438\u0439\u0441\u044f \u043f\u0440\u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u0438\u0438 \u043a\u0443\u0440\u0441\u043e\u0440\u0430.  <\/p>\n<pre><code class=\"sql\">create function mapx_agg_init (inout _agg any) {;}; create function mapx_agg_acc (   inout _agg any,   in _tab integer,   in _oid integer ) {   if (_agg is null)  {     declare img any;     img := img_create (512, 512, _tab[0], _tab[1], _tab[2], _tab[3], 1);     _agg := img;     return 0;   }  else  {     return case       when _tab = 4 then (img_draw_polygone(_agg, (         select blob_to_string(bl.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;building-polygon&quot; as bl          where bl.&quot;_OBJECTID_&quot; = _oid), 255, 255))       when _tab = 3 then (img_draw_polyline(_agg, (         select blob_to_string(hw.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;highway-line&quot; as hw          where hw.&quot;_OBJECTID_&quot; = _oid), 100, 100))        when _tab = 2 then (img_draw_polygone(_agg, (         select blob_to_string(vg.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;vegetation-polygon&quot; as vg         where vg.&quot;_OBJECTID_&quot; = _oid), 10, 10))       when _tab = 1 then (img_draw_polygone(_agg, (         select blob_to_string(wt.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;water-polygon&quot; as wt          where wt.&quot;_OBJECTID_&quot; = _oid), 50, 50))       else 1     end;   } }; create function mapx_agg_final (inout _agg any) returns integer {   declare ptr integer;   ptr := img_tostr (_agg);   img_destroy (_agg);   declare image any;   image := img_fromptr(ptr);   string_to_file('nskx_ii.gif', image, -2);                         return 1; }; create aggregate mapx_agg (in _tab integer, in _oid integer) returns integer   from mapx_agg_init, mapx_agg_acc, mapx_agg_final; create procedure mk_testx_ii_gif(  \tin cminx double precision,  \tin cminy double precision,  \tin cmaxx double precision,  \tin cmaxy double precision) {   declare cnt integer;   select        mapx_agg(tab, oid) into cnt   from (     select * from (select vector(cminx, cminy, cmaxx, cmaxy) as tab, 0 as oid) as f1     union all     (select tab, oid from xxx.YYY.&quot;v_total__spx_enum_items_in_box&quot; as a      where a.minx = cminx and a.miny = cminy and a.maxx = cmaxx and a.maxy = cmaxy)    ) f_all; } mk_testx_ii_gif(35., 50., 45., 60.); <\/code><\/pre>\n<p> \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043d\u0435\u0442 \u0448\u0442\u0430\u0442\u043d\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c \u0430\u0433\u0440\u0435\u0433\u0430\u0442\u0443 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0438\u0434\u0442\u0438 \u043d\u0430 \u0445\u0438\u0442\u0440\u043e\u0441\u0442\u044c, \u043f\u043e\u0434\u0441\u0443\u043d\u0443\u0442\u044c \u0435\u043c\u0443 union \u0438\u0437 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438, \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u043d\u0435 \u0432 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0435, \u0430 \u043f\u0440\u0438 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u0438 \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. <br \/>  \u041a\u0430\u043a \u0436\u0435 \u0442\u0430\u043a, \u0441\u043a\u0430\u0436\u0435\u0442 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044c, \u0431\u044b\u043b \u043e\u0431\u0435\u0449\u0430\u043d \u043e\u0434\u0438\u043d \u0441\u0435\u043b\u0435\u043a\u0442, \u0430 \u0442\u0430\u043c \u0438\u0445 \u0446\u0435\u043b\u0430\u044f \u043a\u0443\u0447\u0430! \u0412 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b \u0441\u0442\u0440\u043e\u043a \u043f\u0440\u0438\u0445\u043e\u0434\u044f\u0442 \u0430\u0433\u0440\u0435\u0433\u0430\u0442\u0443 \u0443\u043f\u043e\u0440\u044f\u0434\u043e\u0447\u0435\u043d\u043d\u043e \u0438 \u043f\u043e\u0442\u0430\u0431\u043b\u0438\u0447\u043d\u043e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043a\u0430\u0436\u0443\u0449\u0438\u0435\u0441\u044f \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u0440\u0443\u043a\u0430\u043c\u0438 join&#8217;\u043e\u043c. <br \/>  \u0418\u0442\u0430\u043a, \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0431\u043e\u0442\u044b 42 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. \u041d\u0434\u0430.<\/p>\n<p>  <b>\u0415\u0449\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0430<\/b>  <\/p>\n<pre><code class=\"sql\">create procedure mk_testx_gif(  \tin cminx double precision,  \tin cminy double precision,  \tin cmaxx double precision,  \tin cmaxy double precision) {   declare img any;   img := img_create (512, 512, cminx, cminy, cmaxx, cmaxy, 1);   declare cnt, cnt2 integer;   declare cl1, bg1 integer;   cl1 := img_alloc_color (img, 0, 0, 255);   bg1 := img_alloc_color (img, 0, 0, 255);   declare cl2, bg2 integer;   cl2 := img_alloc_color (img, 0, 255, 0);   bg2 := img_alloc_color (img, 0, 255, 0);   declare cl3, bg3 integer;   cl3 := img_alloc_color (img, 255, 100, 0);   bg3 := img_alloc_color (img, 255, 100, 0);   declare cl4, bg4 integer;   cl4 := img_alloc_color (img, 255, 0, 0);   bg4 := img_alloc_color (img, 255, 0, 0);   select      sum (       case         when geom is null then 0         when geom_type = 2 then (img_draw_polyline(img, geom, cl, bg))          else (img_draw_polygone(img, geom, cl, bg))       end      ) into cnt   from (      select        case         when a.tab = 4 then (            select blob_to_string(bl.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;building-polygon&quot; as bl             where bl.&quot;_OBJECTID_&quot; = a.oid)         when a.tab = 3 then (            select blob_to_string(hw.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;highway-line&quot; as hw             where hw.&quot;_OBJECTID_&quot; = a.oid)         when a.tab = 2 then (            select blob_to_string(vg.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;vegetation-polygon&quot; as vg             where vg.&quot;_OBJECTID_&quot; = a.oid)         when a.tab = 1 then (            select blob_to_string(wt.Shape) from &quot;xxx&quot;.&quot;YYY&quot;.&quot;water-polygon&quot; as wt             where wt.&quot;_OBJECTID_&quot; = a.oid)         else ''       end as geom,        case when a.tab = 3 then 2 else 1 end as geom_type,       case when a.tab = 4 then cl4             when a.tab = 3 then cl3             when a.tab = 2 then cl2             when a.tab = 1 then cl1 else 0 end as cl,       case when a.tab = 4 then bg4             when a.tab = 3 then bg3             when a.tab = 2 then bg2             when a.tab = 1 then bg1 else 0 end as bg     from       xxx.YYY.&quot;v_total__spx_enum_items_in_box&quot; as a     where a.minx = cminx and a.miny = cminy             and a.maxx = cmaxx and a.maxy = cmaxy   ) f_all;   declare ptr integer;   ptr := img_tostr (img);   img_destroy (img);   declare image any;   image := img_fromptr(ptr);   string_to_file('testx.gif', image, -2);   return; }; mk_testx_gif(35., 50., 45., 60.); <\/code><\/pre>\n<p>\u042d\u0442\u043e\u0442 \u0437\u0430\u043f\u0440\u043e\u0441 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 17.4 \u0441\u0435\u043a\u0443\u043d\u0434\u044b. \u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440 \u0441\u043c\u043e\u0433 \u0440\u0430\u0441\u043f\u043e\u0437\u043d\u0430\u0442\u044c \u0441\u043a\u0440\u044b\u0442\u044b\u0435 join&#8217;\u044b \u0438 \u0438\u0441\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441 \u0431\u0435\u0437 \u043e\u0441\u043e\u0431\u044b\u0445 \u043f\u043e\u0442\u0435\u0440\u044c \u0437\u0430 \u043a\u0440\u0430\u0441\u043e\u0442\u0443. \u0410 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0432\u044b\u0438\u0433\u0440\u044b\u0448 \u0432 \u0440\u0430\u0431\u043e\u0442\u0435 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u0431\u044b\u043b \u0441\u044a\u0435\u0434\u0435\u043d \u0432\u043e\u0437\u0440\u043e\u0441\u0448\u0435\u0439 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u0437\u0430\u043f\u0440\u043e\u0441\u0430. <\/p>\n<p>  \u0410 \u0432\u043e\u0442 \u0438 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442: <br \/>  <img decoding=\"async\" src=\"http:\/\/habrastorage.org\/storage3\/2a9\/f64\/68d\/2a9f6468d545504a0ed7c339e88ac209.gif\" alt=\"image\"\/><br \/>  \u0412 \u044d\u0442\u043e\u0439 \u043d\u0435\u0432\u0437\u0440\u0430\u0447\u043d\u043e\u0439 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432.<\/p>\n<h4><b>\u0412\u044b\u0432\u043e\u0434\u044b<\/b><\/h4>\n<p>  \u041d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u0440\u0442\u0443 \u043e\u0434\u043d\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c \u043d\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043e\u0441\u043e\u0431\u043e\u0433\u043e \u0442\u0440\u0443\u0434\u0430. \u041d\u0430\u043c \u0434\u0430\u0436\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e \u043d\u0435 \u043f\u043e\u0442\u0435\u0440\u044f\u0432 \u043e\u0441\u043e\u0431\u043e \u0432 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438. \u0412\u044b\u0438\u0433\u0440\u0430\u0442\u044c, \u043f\u0440\u0430\u0432\u0434\u0430, \u0442\u043e\u0436\u0435 \u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0438 \u043f\u0440\u0438\u0447\u0438\u043d\u0430 \u043f\u043e \u0432\u0441\u0435\u0439 \u0432\u0438\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0432 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 \u0434\u0430\u043d\u043d\u044b\u0445. \u0410 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u044d\u0442\u0430 \u0437\u0430\u0442\u043e\u0447\u0435\u043d\u0430 \u043f\u043e\u0434 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0442\u0440\u0430\u0434\u0438\u0446\u0438\u043e\u043d\u043d\u044b\u043c\u0438 \u0413\u0418\u0421.<\/p>\n<p>  \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0442\u0430\u0431\u043b\u0438\u0446\u0430 &#8216;highway-line&#8217; \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0432 \u0441\u0435\u0431\u0435 \u043f\u0430\u0440\u0443 \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0441\u043b\u043e\u0435\u0432 \u0440\u0430\u0437\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432, \u043e\u0442\u043b\u0438\u0447\u0430\u044e\u0449\u0438\u0445\u0441\u044f \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430\u043c\u0438. \u041e\u0431\u044b\u0447\u043d\u043e, \u0442\u0430\u043a\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441\u043b\u0443\u0436\u0430\u0442 \u043e\u0441\u043d\u043e\u0432\u043e\u0439 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u0434\u043e\u0440\u043e\u0436\u043d\u044b\u0445 \u0441\u043b\u043e\u0435\u0432, \u0441\u0441\u044b\u043b\u0430\u044e\u0449\u0438\u0445\u0441\u044f \u043d\u0430 \u043e\u0434\u043d\u0443 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0438 \u043e\u0442\u043b\u0438\u0447\u0430\u044e\u0449\u0438\u0445\u0441\u044f \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u043c\u0438. \u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u0443\u0434\u043e\u0431\u043d\u0435\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u043e\u0434\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u043d\u0435\u0436\u0435\u043b\u0438 \u0441 \u0434\u0432\u0443\u043c\u044f \u0434\u0435\u0441\u044f\u0442\u043a\u0430\u043c\u0438 (\u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0431\u044b\u043b \u0438 \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u043c\u043e\u0442\u0438\u0432\u043e\u0432 \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b). \u041e\u043f\u044f\u0442\u044c \u0436\u0435, \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u043e\u0431\u0449\u0438\u0439 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u0434\u043b\u044f \u0432\u0430\u0441\u0435\u0445 \u044d\u0442\u0438\u0445 \u0441\u043b\u043e\u0435\u0432. <\/p>\n<p>  \u041d\u043e \u0435\u0441\u0442\u044c \u0438 \u043c\u0438\u043d\u0443\u0441\u044b. \u041f\u043e-\u043f\u0440\u0435\u0436\u043d\u0435\u043c\u0443, \u0434\u043b\u044f \u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0441\u043b\u043e\u044f \u043d\u0430\u0434\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 SQL \u0437\u0430\u043f\u0440\u043e\u0441. \u0422.\u0435. \u0445\u043e\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441 \u0438 \u043e\u0434\u0438\u043d, \u043f\u043e\u0438\u0441\u043a\u043e\u0432 \u043f\u043e \u043d\u0435\u043c\u0443 \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e. \u041c\u0430\u043a\u0441\u0438\u043c\u0443\u043c, \u043d\u0430 \u0447\u0435\u043c \u0442\u0443\u0442 \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u0438\u0433\u0440\u0430\u0442\u044c, \u044d\u0442\u043e \u043d\u0430 \u043a\u044d\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446. \u041d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u2014 \u0442\u0438\u043f \u0437\u0430\u043f\u0438\u0441\u0438, \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0438\u0441\u043a\u0430\u0442\u044c \u0435\u0449\u0435 \u0438 \u043f\u043e \u043d\u0435\u043c\u0443 \u0438 \u043f\u0435\u0440\u0435\u0441\u0435\u043a\u0430\u0442\u044c \u0432\u044b\u0431\u043e\u0440\u043a\u0438. \u041a\u0440\u043e\u043c\u0435 \u0442\u043e\u0433\u043e, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u0440\u0430\u0437\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432 \u0438\u0434\u0443\u0442 \u0432\u043f\u0435\u0440\u0435\u043c\u0435\u0448\u043a\u0443, \u043c\u0430\u043b\u043e \u0448\u0430\u043d\u0441\u043e\u0432, \u0447\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u043e\u0434\u043d\u043e\u0433\u043e \u0442\u0438\u043f\u0430 \u043e\u043a\u0430\u0436\u0443\u0442\u0441\u044f \u0440\u044f\u0434\u043e\u043c (\u043d\u0430 \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435) \u0438 \u0442\u0435\u043c \u0441\u0430\u043c\u044b\u043c \u0432\u043e\u0437\u0440\u0430\u0441\u0442\u0430\u0435\u0442 \u043e\u0431\u0449\u0435\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0447\u0442\u0435\u043d\u0438\u0439.<\/p>\n<p>  \u0427\u0442\u043e \u0435\u0441\u043b\u0438 \u043c\u044b \u0440\u0430\u0441\u043a\u0438\u0434\u0430\u0435\u043c, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0442\u0430\u0431\u043b\u0438\u0446\u0443 &#8216;highway-line&#8217; \u043d\u0430 \u043a\u0443\u0447\u0443 \u043f\u043e\u0434\u0442\u0430\u0431\u043b\u0438\u0446 \u043f\u043e \u0442\u0438\u043f\u0430\u043c \u0438 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0438\u043c \u0432\u0441\u0435 \u0438\u0445 \u0432 \u043e\u0434\u043d\u043e\u043c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435, \u043a\u0430\u043a \u0434\u0435\u043b\u0430\u043b\u0438 \u044d\u0442\u043e \u0432\u044b\u0448\u0435? \u0420\u0430\u0431\u043e\u0442\u0430 \u0441 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c \u043e\u0442 \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f, \u043d\u0430\u043c \u043d\u0443\u0436\u0435\u043d \u0431\u0443\u0434\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u043f\u043e\u0438\u0441\u043a \u0432 \u043d\u0451\u043c. \u0420\u0430\u0431\u043e\u0442\u0430 \u0441 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u0441\u044f \u0442.\u043a. \u043f\u043e\u0432\u044b\u0441\u0438\u0442\u0441\u044f \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0445 \u2014 \u0434\u0430\u043d\u043d\u044b\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0442\u0438\u043f\u0430, \u0431\u043b\u0438\u0437\u043a\u0438\u0435 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0447\u0430\u0449\u0435 \u0431\u0443\u0434\u0443\u0442 \u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0440\u044f\u0434\u043e\u043c \u043d\u0430 \u0434\u0438\u0441\u043a\u0435. \u0410 \u0435\u0441\u043b\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u043a\u0430\u043a\u043e\u0433\u043e-\u043b\u0438\u0431\u043e \u0442\u0438\u043f\u0430 \u043d\u0435\u0442 \u0432 \u043f\u043e\u0438\u0441\u043a\u043e\u0432\u043e\u043c \u044d\u043a\u0441\u0442\u0435\u043d\u0442\u0435, \u043e\u043d\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0431\u0443\u0434\u0443\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f. \u0421\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u044b \u0438\u0445 \u043d\u0438 \u0431\u044b\u043b\u043e, \u044d\u0442\u043e \u043d\u0438\u043a\u0430\u043a \u043d\u0435 \u0441\u043a\u0430\u0436\u0435\u0442\u0441\u044f \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0438 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445. <\/p>\n<p>  \u0418 \u0435\u0449\u0435 \u043e\u0434\u043d\u043e \u043d\u0430\u0431\u043b\u044e\u0434\u0435\u043d\u0438\u0435 \u043d\u0430\u043f\u043e\u0441\u043b\u0435\u0434\u043e\u043a. \u0418\u043d\u0434\u0435\u043a\u0441\u044b \u043a\u0430\u043a \u0442\u0430\u043a\u043e\u0432\u044b\u0435 \u0441\u0443\u0442\u044c \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0441\u0442\u0440\u0430\u043d\u043d\u044b\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u044b. \u041d\u0438 \u0432 \u0440\u0435\u043b\u044f\u0446\u0438\u043e\u043d\u043d\u043e\u0439 \u0430\u043b\u0433\u0435\u0431\u0440\u0435, \u043d\u0438 \u0432 \u0440\u0435\u043b\u044f\u0446\u0438\u043e\u043d\u043d\u043e\u043c \u0438\u0441\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0438 \u0438\u0445 \u0438 \u0431\u043b\u0438\u0437\u043a\u043e \u043d\u0435\u0442. \u042d\u0442\u043e \u0437\u0430\u0432\u0438\u0441\u044f\u0449\u0435\u0435 \u043e\u0442 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u0443 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0441\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0438\u0445 \u0431\u043e\u043b\u0435\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e. \u0412 \u043d\u0430\u0448\u0435\u043c \u0436\u0435 \u0441\u043b\u0443\u0447\u0430\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430\u0433\u0440\u0443\u0436\u0435\u043d\u044b \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043d\u0435\u0442 \u0432 \u0434\u0430\u043d\u043d\u044b\u0445. \u0412 \u043d\u0430\u0448\u0435\u043c \u043c\u043d\u043e\u0433\u043e\u0442\u0430\u0431\u043b\u0438\u0447\u043d\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u044b \u0432\u0437\u0430\u0438\u043c\u043e\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u044f \u043c\u0435\u0436\u0434\u0443 \u0441\u043b\u043e\u044f\u043c\u0438, \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u0432 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u0435 \u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0442\u0435 \u0441\u043b\u043e\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0436\u0435\u043b\u0430\u0435\u043c \u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0432\u043c\u0435\u0441\u0442\u0435. <\/p>\n<p>  \u0421 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043c\u044b \u043d\u0435 \u043c\u043e\u0436\u0435\u043c \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0442\u044c \u043d\u0430\u0448 \u0438\u043d\u0434\u0435\u043a\u0441 \u043a\u0430\u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0443 (\u0445\u043e\u0442\u044f \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u043d \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439, \u044d\u0442\u043e \u0432\u044b\u043d\u0443\u0436\u0434\u0435\u043d\u043d\u0430\u044f \u043c\u0435\u0440\u0430 \u0432 \u0441\u0438\u043b\u0443 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043c\u044b \u0432\u044b\u043d\u0443\u0436\u0434\u0435\u043d\u044b \u043e\u0441\u0442\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u0432 \u0440\u0430\u043c\u043a\u0430\u0445 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0421\u0423\u0411\u0414) \u0442.\u043a. \u0435\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b \u0442\u0430\u0431\u043b\u0438\u0446. \u042d\u0442\u043e \u043c\u0435\u0442\u0430\u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u0438 \u043f\u043b\u0430\u043d \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445 \u0438\u0437 \u044d\u0442\u043e\u0439 \u043d\u0435\u0451.<\/p>\n<p>  \u041e\u043f\u044f\u0442\u044c \u0436\u0435, \u0442\u0440\u0430\u0434\u0438\u0446\u0438\u043e\u043d\u043d\u043e, \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0432\u043e\u043b\u0435\u043d \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043a\u0430\u043a\u0438\u043c\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 \u0435\u043c\u0443 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f. \u041d\u043e \u044d\u0442\u043e \u043d\u0435 \u043d\u0430\u0448 \u0441\u043b\u0443\u0447\u0430\u0439. \u041c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u043d\u043e\u0433\u043e\u0442\u0430\u0431\u043b\u0438\u0447\u043d\u044b\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0438 \u044f\u0432\u043d\u043e \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c, \u043a\u0430\u043a\u043e\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u0441\u043b\u0443\u0436\u0438\u0442 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u043e\u043c \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043a\u0430 \u0434\u0430\u043d\u043d\u044b\u0445. \u0412\u043d\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043f\u043e \u044d\u0442\u043e\u043c\u0443 \u043f\u043e\u0432\u043e\u0434\u0443 \u0434\u0443\u043c\u0430\u0435\u0442 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440. \u041f\u0440\u0438\u044f\u0442\u043d\u043e \u0432\u0438\u0434\u0435\u0442\u044c, \u043a\u0430\u043a \u00ab\u0434\u0440\u0435\u0432\u043e \u0436\u0438\u0437\u043d\u0438 \u0432\u0435\u0447\u043d\u043e \u0437\u0435\u043b\u0435\u043d\u0435\u0435\u0442\u00bb \u0441\u043a\u0432\u043e\u0437\u044c \u00ab\u0441\u0443\u0445\u0443\u044e \u0442\u0435\u043e\u0440\u0438\u044e\u00bb \u0440\u0435\u043b\u044f\u0446\u0438\u043e\u043d\u043d\u043e\u0439 \u043c\u043e\u0434\u0435\u043b\u0438.<\/p>\n<h4><b>PS:<\/b><\/h4>\n<p><i>\u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0438\u043b\u043b\u044e\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0432 \u0448\u0430\u043f\u043a\u0435 \u0441\u0442\u0430\u0442\u044c\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d \u0447\u0443\u0434\u0435\u0441\u043d\u044b\u0439 &#8216;\u043f\u043b\u0430\u043d \u0433\u043e\u0440\u043e\u0434\u0430 \u041f\u0430\u0440\u0438\u0436\u0430&#8217; \u0440\u0443\u043a\u0438 \u041c\u0430\u0440\u043a\u0430 \u0422\u0432\u0435\u043d\u0430 \u0438\u0437 \u043e\u0434\u043d\u043e\u0438\u043c\u0435\u043d\u043d\u043e\u0433\u043e \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430.<\/i>    \t<\/p>\n<div class=\"clear\"><\/div>\n<\/p><\/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=\"http:\/\/habrahabr.ru\/post\/201474\/\"> http:\/\/habrahabr.ru\/post\/201474\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">   \t<img decoding=\"async\" src=\"http:\/\/habr.habrastorage.org\/post_images\/cf2\/f0a\/52b\/cf2f0a52b2b81dea98931ffeab19466e.png\" alt=\"image\"\/><br \/>  \u0414\u0430\u043d\u043d\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0430 \u0432 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435 \u0441\u0435\u0440\u0438\u0438, \u043f\u043e\u0432\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u043e \u043f\u0440\u043e\u0442\u043e\u0442\u0438\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e web map \u0441\u0435\u0440\u0432\u0435\u0440\u0430. <a href=\"http:\/\/habrahabr.ru\/post\/196682\/\">\u0420\u0430\u043d\u0435\u0435<\/a> \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u043b\u043e\u0441\u044c \u043e \u0442\u043e\u043c, \u043a\u0430\u043a \u0432 \u043d\u0435\u043c \u0443\u0441\u0442\u0440\u043e\u0435\u043d\u044b \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0430 \u0442\u0430\u043a \u0436\u0435 \u043e \u0442\u043e\u043c, <a href=\"http:\/\/habrahabr.ru\/post\/200642\/\">\u043a\u0430\u043a<\/a> \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0442\u0430\u043a \u0432\u043e\u0442 \u0432\u0437\u044f\u0442\u044c \u0438 \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0441\u043b\u043e\u0439. \u0421\u0435\u0439\u0447\u0430\u0441 \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u044d\u0442\u043e \u0447\u0443\u0442\u044c \u0438\u0437\u044f\u0449\u043d\u0435\u0435.  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-201474","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/201474","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=201474"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/201474\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=201474"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=201474"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=201474"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}