{"id":326306,"date":"2021-07-12T09:00:46","date_gmt":"2021-07-12T09:00:46","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=326306"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=326306","title":{"rendered":"\u041f\u043e\u0447\u0435\u043c\u0443 \u043c\u044b \u043f\u0435\u0440\u0435\u0448\u043b\u0438 \u0441 Oracle \u043d\u0430 PostgreSQL, \u0438 \u043a\u0430\u043a \u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c"},"content":{"rendered":"\n<div class=\"post__text post__text-html post__text_v1\" id=\"post-content-body\">\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/bt\/ty\/bt\/bttybtihoctlceu7hdwzvecwrmc.jpeg\"><\/p>\n<p>  <\/p>\n<p>\u0412\u0441\u0435\u043c \u043f\u0440\u0438\u0432\u0435\u0442!<br \/>  \u0421\u0435\u0433\u043e\u0434\u043d\u044f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0435\u043c \u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u043e\u0432\u043e\u0439 \u0434\u043b\u044f \u043d\u0430\u0441 \u0442\u0435\u043c\u0435 \u2014 \u043f\u0440\u043e \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0441 Oracle \u043d\u0430 Postgres Pro (\u0434\u0430\u043b\u0435\u0435 \u0432 \u0442\u0435\u043a\u0441\u0442\u0435 \u0432\u0435\u0437\u0434\u0435 \u0441\u043e\u043a\u0440\u0430\u0449\u0443 \u0434\u043e PG). \u0412 \u043e\u0431\u0449\u0435\u043c \u0441\u043c\u044b\u0441\u043b\u0435 \u0442\u0435\u043c\u0430 \u043d\u0435 \u0441\u0442\u043e\u043b\u044c \u0443\u0436 \u043d\u043e\u0432\u0430 \u2014 \u043c\u043d\u043e\u0433\u0438\u0435 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u044d\u0442\u0438\u043c \u0442\u0430\u043a\u0436\u0435 \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u0443\u0436\u0435 \u043f\u0440\u043e\u0448\u043b\u0438 \u044d\u0442\u043e\u0442 \u043f\u0443\u0442\u044c. \u0422\u0430\u043a, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043d\u0430 \u0435\u0436\u0435\u0433\u043e\u0434\u043d\u043e\u0439 \u043a\u043e\u043d\u0444\u0435\u0440\u0435\u043d\u0446\u0438\u0438 pgConf \u0432\u0441\u0435\u0433\u0434\u0430 \u0435\u0441\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 \u0434\u043e\u043a\u043b\u0430\u0434\u043e\u0432 \u043f\u043e \u044d\u0442\u043e\u0439 \u0442\u0435\u043c\u0435 (<a href=\"https:\/\/pgconf.ru\/\">https:\/\/pgconf.ru\/<\/a>). \u0415\u0441\u043b\u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043e \u0444\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044f\u0445, \u0442\u043e \u043c\u044b \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0438\u043d\u0438\u0446\u0438\u0430\u0442\u0438\u0432\u0443 \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u043e (<a href=\"https:\/\/digital.gov.ru\/ru\/documents\/4548\/\">\u041f\u0440\u0438\u043a\u0430\u0437 \u041c\u0438\u043d\u0438\u0441\u0442\u0435\u0440\u0441\u0442\u0432\u0430 \u0441\u0432\u044f\u0437\u0438 \u00ab\u041e\u0431 \u0443\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043d\u0438\u0438 \u043f\u043b\u0430\u043d\u0430 \u043f\u043e \u0438\u043c\u043f\u043e\u0440\u0442\u043e\u0437\u0430\u043c\u0435\u0449\u0435\u043d\u0438\u044e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u0433\u043e \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0435\u043d\u0438\u044f\u00bb \u043e\u0442 01.02.2015 \u2116 96<\/a>). \u041f\u043e \u0444\u0430\u043a\u0442\u0443 \u2014 \u0435\u0449\u0451 \u0438 \u0434\u0435\u043d\u0435\u0433 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u043c, \u0441\u043b\u0435\u0437\u0430\u044f \u0441 &quot;\u043b\u0438\u0446\u0435\u043d\u0437\u0438\u043e\u043d\u043d\u043e\u0439 \u0438\u0433\u043b\u044b&quot;. \u041d\u0430 \u044d\u0442\u0443 \u0442\u0435\u043c\u0443 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u0441\u0442\u0430\u0442\u044c\u044e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c, \u0430 \u0432 \u044d\u0442\u043e\u0439 \u0440\u0435\u0447\u044c \u043f\u043e\u0439\u0434\u0451\u0442 \u043e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u0430. \u041a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e, \u0434\u043e\u0431\u0440\u043e \u043f\u043e\u0436\u0430\u043b\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434 \u043a\u0430\u0442.<\/p>\n<p><a name=\"habracut\"><\/a>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u0421\u043f\u043e\u0439\u043b\u0435\u0440<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<p>\u041f\u0440\u0435\u0434\u0432\u043e\u0441\u0445\u0438\u0449\u0430\u044f \u0445\u0435\u0439\u0442\u0435\u0440\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0433\u0443\u0442 \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e, \u043c\u043e\u043b, PG \u0431\u044b\u043b \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043d (\u0442\u0430\u043c-\u0442\u043e \u0438 \u0442\u0430\u043c-\u0442\u043e, \u0430 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u0435\u0435 \u0432 \u0411\u0435\u0440\u043a\u043b\u0438) \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f open-source, \u043e\u0442\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u0441\u043e\u0433\u043b\u0430\u0441\u0435\u043d \u0441 \u043d\u0438\u043c\u0438. \u041e\u0434\u043d\u0430\u043a\u043e \u0432 \u043c\u0438\u0440\u0435 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0433\u043e \u041f\u041e \u0442\u0430\u043a\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430 \u0441\u0435\u0433\u043e\u0434\u043d\u044f \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u0430: \u0431\u0435\u0440\u0451\u043c \u0445\u043e\u0440\u043e\u0448\u0438\u0439 \u043e\u043f\u0435\u043d\u0441\u043e\u0440\u0441, \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u0444\u0438\u0447\u0438, \u043f\u0440\u043e\u0434\u0430\u0435\u043c \u043a\u0430\u043a \u0441\u0432\u043e\u0439 \u043f\u0440\u043e\u0434\u0443\u043a\u0442, \u0432 \u0434\u043e\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044f (\u0438\/\u0438\u043b\u0438 \u043f\u0440\u043e\u0434\u0430\u0432\u0430\u044f) \u0442\u0435\u0445\u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0443. \u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0440\u0435\u0431\u044f\u0442\u0430 \u0438\u0437 PostgresPro \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u0438\u043c \u0438 \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f (\u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u044f \u0442\u0430\u043a\u0436\u0435 \u043a\u043e\u043d\u0442\u0440\u0438\u0431\u044c\u044e\u0442\u0438\u0442\u044c \u0432 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439 \u043f\u0440\u043e\u0435\u043a\u0442). \u0424\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e \u0436\u0435 \u0434\u043b\u044f \u043d\u0430\u0441 \u0442\u0430\u043a\u0436\u0435 \u0432\u0430\u0436\u043d\u043e \u0442\u043e, \u0447\u0442\u043e \u041f\u041e \u0432\u0445\u043e\u0434\u0438\u0442 \u0432 \u043f\u0435\u0440\u0435\u0447\u0435\u043d\u044c \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u043e\u0433\u043e \u041f\u041e (\u0442.\u0435. \u043d\u0430 \u0437\u0430\u043a\u043e\u043d\u043e\u0434\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u043c \u0443\u0440\u043e\u0432\u043d\u0435).<\/p>\n<\/div><\/div>\n<p>  <\/p>\n<h2 id=\"vmesto-vvedeniya\">\u0412\u043c\u0435\u0441\u0442\u043e \u0432\u0432\u0435\u0434\u0435\u043d\u0438\u044f<\/h2>\n<p>  <\/p>\n<p>\u0415\u0441\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f, \u0433\u0434\u0435 \u043e\u0431\u0437\u043e\u0440\u043d\u043e \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e \u0442\u0435\u043a\u0443\u0449\u0435\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0421\u0423\u0411\u0414 PG \u0438 \u043f\u043e\u0434\u0441\u0432\u0435\u0447\u0435\u043d\u044b \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b, \u0435\u0441\u043b\u0438 \u0435\u0449\u0435 \u043d\u0435 \u0447\u0438\u0442\u0430\u043b\u0438 \u2014 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435: <a href=\"https:\/\/habr.com\/ru\/company\/tensor\/blog\/553754\/\">https:\/\/habr.com\/ru\/company\/tensor\/blog\/553754\/<\/a><\/p>\n<p>  <\/p>\n<h2 id=\"chto-budem-migrirovat\">\u0427\u0442\u043e \u0431\u0443\u0434\u0435\u043c \u043c\u0438\u0433\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c<\/h2>\n<p>  <\/p>\n<p>\u041d\u0435 \u0431\u0443\u0434\u0443 \u0437\u0430\u043e\u0441\u0442\u0440\u044f\u0442\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0431\u0438\u0437\u043d\u0435\u0441 \u0441\u043c\u044b\u0441\u043b, \u043f\u043e\u0433\u0440\u0443\u0436\u0443\u0441\u044c \u0432 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0449\u0443\u044e.<br \/>  \u041d\u0430 \u0441\u0442\u0430\u0440\u0442\u0435 \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c: \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435:<\/p>\n<p>  <\/p>\n<ul>\n<li>\u0438\u043c\u0435\u0435\u0442 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435 \u0441\u0432\u044f\u0437\u0438;<\/li>\n<li>\u0438\u043c\u0435\u0435\u0442 \u0432\u0435\u0431-\u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 (\u0431\u044d\u043a\u044d\u043d\u0434 \u0438 \u0444\u0440\u043e\u043d\u0442\u044d\u043d\u0434 \u0447\u0430\u0441\u0442\u0438);<\/li>\n<li>\u043c\u043e\u0434\u0443\u043b\u044c \u0440\u0430\u0441\u0447\u0435\u0442\u0430; <\/li>\n<li>\u043c\u043e\u0434\u0443\u043b\u044c \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043e\u0442\u0447\u0435\u0442\u043e\u0432;<\/li>\n<li>\u0414\u0430\u043d\u043d\u044b\u0435 \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0432 Oracle 12.<br \/>  \u0421\u0442\u0435\u043a \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u2014 java\/kotlin \u0432\u043f\u0435\u0440\u0435\u043c\u0435\u0436\u043a\u0443, spring, \u0440\u0430\u0437\u0443\u043c\u0435\u0435\u0442\u0441\u044f hibernate. \u0427\u0430\u0441\u0442\u044c \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439 \u043f\u043e\u0434\u043d\u044f\u0442\u044b \u043d\u0430 glassfish, \u0447\u0430\u0441\u0442\u044c \u0430\u0432\u0442\u043e\u043d\u043e\u043c\u043d\u044b \u043d\u0430 spring boot. \u0422\u0430\u043a\u043e\u0435 \u0432\u043e\u0442 \u043d\u0430\u0441\u043b\u0435\u0434\u0438\u0435.<\/li>\n<\/ul>\n<p>  <\/p>\n<h2 id=\"cennosti-migracii\">\u00ab\u0426\u0435\u043d\u043d\u043e\u0441\u0442\u0438\u00bb \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438<\/h2>\n<p>  <\/p>\n<p>\u041e\u0431\u043e\u0437\u043d\u0430\u0447\u0438\u043c \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u00ab\u0446\u0435\u043d\u043d\u043e\u0441\u0442\u0438\u00bb \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438. \u041e\u043d\u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a\u043e\u0432\u044b:<\/p>\n<p>  <\/p>\n<ol>\n<li>\u0418\u0434\u0435\u0442 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e\u0435 \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u0438 \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u043b\u0438\u043d\u0435\u0439\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u044f \u043d\u0435 \u0441\u0442\u043e\u0438\u0442 \u00ab\u043c\u0435\u0448\u0430\u0442\u044c\u00bb \u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0435 \u0440\u0430\u0431\u043e\u0442\u0443, \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043a\u043e\u043c\u0430\u043d\u0434\u0443 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u043c\u044b \u0440\u0435\u0448\u0438\u043b\u0438 \u0432\u044b\u0434\u0435\u043b\u0438\u0442\u044c \u0432 \u00ab\u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u0431\u043e\u0435\u0432\u0443\u044e \u0435\u0434\u0438\u043d\u0438\u0446\u0443\u00bb;<\/li>\n<li>\u041f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0434\u043e\u043b\u0436\u043d\u044b (\u0431\u0443\u0434\u0443\u0442) \u0443\u043c\u0435\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043a\u0430\u043a \u0441 Oracle, \u0442\u0430\u043a \u0438 \u0441 PG. \u041f\u043e\u0441\u0447\u0438\u0442\u0430\u043b\u0438, \u0447\u0442\u043e \u0432 \u0442\u0430\u043a\u043e\u043c \u0432\u0438\u0434\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u043e\u0449\u0435 \u0432\u0435\u0441\u0442\u0438 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u0443\u044e \u0440\u0430\u0431\u043e\u0442\u0443 \u0434\u0432\u0443\u0445 \u043a\u043e\u043c\u0430\u043d\u0434 \u2014 \u043d\u0435 \u0432\u044b\u0434\u0435\u043b\u044f\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0432\u0435\u0440\u0441\u0438\u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439 \u0438 \u0442.\u0434. \u041e\u0434\u043d\u0430\u043a\u043e \u044d\u0442\u043e \u0440\u043e\u0436\u0434\u0430\u0435\u0442 \u0438 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438, \u043e \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043d\u0438\u0436\u0435.<\/li>\n<li>\u0412 \u0440\u0430\u043c\u043a\u0430\u0445 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u043d\u0435 \u043f\u0440\u043e\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043e\u043a (\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0445, \u0431\u0438\u0437\u043d\u0435\u0441\u043e\u0432\u044b\u0445), \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0440\u0435\u0448\u0430\u0435\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043e\u043f\u0440\u043e\u0441 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438, \u0432\u0441\u0435 \u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u0434\u0435\u043b\u0430\u044e\u0442\u0441\u044f \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c\u0441\u044f \u043d\u0430 \u043d\u043e\u0432\u043e\u043c \u043e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0438;<\/li>\n<li>\u041c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u043d\u0438\u0447\u0435\u0433\u043e \u0443\u0445\u0443\u0434\u0448\u0438\u0442\u044c (\u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c, \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b). \u041e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0439 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e\u0441\u0442\u0438 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u2014 \u043f\u0440\u043e\u0445\u043e\u0436\u0434\u0435\u043d\u0438\u0435 \u0442\u0435\u0441\u0442\u043e\u0432. \u0414\u0430\u043d\u043d\u044b\u0435 \u0432 \u043e\u0442\u0447\u0435\u0442\u0430\u0445 \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u044b \u00ab\u043e\u0440\u0430\u043a\u043b\u043e\u0432\u043e\u043c\u0443 \u043a\u043e\u043d\u0442\u0443\u0440\u0443\u00bb.<\/li>\n<\/ol>\n<p>  <\/p>\n<h2 id=\"podhody-k-migracii\">\u041f\u043e\u0434\u0445\u043e\u0434\u044b \u043a \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438<\/h2>\n<p>  <\/p>\n<p>\u041d\u0430\u0441\u0442\u0430\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u043e\u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430\u0445. \u0411\u0443\u0434\u0435\u043c \u0447\u0435\u0441\u0442\u043d\u044b, \u043e\u043f\u044b\u0442\u0430 \u0442\u0430\u043a\u043e\u0439 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u0432 \u043d\u0430\u0448\u0435\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u0435\u0449\u0435 \u043d\u0435 \u0431\u044b\u043b\u043e. \u0417\u0430\u0442\u043e \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0445\u043e\u0440\u043e\u0448\u0430\u044f \u044d\u043a\u0441\u043f\u0435\u0440\u0442\u0438\u0437\u0430 \u043d\u0430 PG, \u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 \u043f\u0440\u043e\u0435\u043a\u0442\u044b \u0440\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c \u043d\u0430 \u043d\u0435\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0434\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0430\u0434\u043e \u043e\u0433\u043b\u044f\u0434\u0435\u0442\u044c\u0441\u044f, \u043a\u0430\u043a \u043b\u044e\u0434\u0438 \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u044e\u0442, \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c, \u043f\u043e\u0441\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0442\u044c. \u0417\u0434\u0435\u0441\u044c \u043d\u0430\u043c \u043f\u043e\u0432\u0435\u0437\u043b\u043e, \u043a\u0430\u043a \u0440\u0430\u0437 \u043d\u0435 \u0442\u0430\u043a \u0434\u0430\u0432\u043d\u043e \u043c\u044b \u0431\u044b\u043b\u0438 \u043d\u0430 pgConf, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0431\u044b\u043b\u043e \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043e\u0447\u0435\u043d\u044c \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0445 \u0434\u043e\u043a\u043b\u0430\u0434\u043e\u0432 \u043d\u0430 \u0442\u0435\u043c\u0443 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438. \u0412\u043e\u0442 \u043e\u043d\u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043e\u0442 2020 \u0433\u043e\u0434\u0430 \u2014 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u0432\u0441\u0435\u043c \u0436\u0435\u043b\u0430\u044e\u0449\u0438\u043c: <a href=\"https:\/\/pgconf.ru\/2020\/talks-and-tutorials\">https:\/\/pgconf.ru\/2020\/talks-and-tutorials<\/a>. \u0415\u0441\u043b\u0438 \u043d\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438, \u043d\u0430\u0447\u043d\u0438\u0442\u0435 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0441 \u0410\u043d\u0430\u0442\u043e\u043b\u0438\u044f \u0410\u0444\u0438\u043d\u043e\u0433\u0435\u043d\u043e\u0432\u0430 (\u0420\u0416\u0414) \u2014 \u043f\u0440\u043e\u0441\u0442\u043e, \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e \u0438 \u043f\u043e\u0437\u043d\u0430\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e. \u041d\u043e \u0442\u0430\u043c \u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u043e\u0447\u0435\u043d\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0435.<br \/>  \u0412 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0433\u0443\u0433\u043b\u0435\u043d\u0438\u044f \u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442\u0430 \u0431\u044b\u043b \u043d\u0430\u0439\u0434\u0435\u043d \u043e\u0447\u0435\u043d\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0439 \u0444\u043e\u043b\u0438\u0430\u043d\u0442 \u2014 Oracle to Azure Database for PostgreSQL Migration Guide. \u041f\u0443\u0441\u0442\u044c \u0432\u0430\u0441 \u0441\u043b\u043e\u0432\u043e \u00abAzure\u00bb \u043d\u0435 \u043e\u0442\u043f\u0443\u0433\u043d\u0435\u0442, \u0442\u0430\u043c \u0432\u0441\u0435 \u043f\u043e \u0434\u0435\u043b\u0443 \u0438 \u0432\u0441\u0435 \u043f\u0440\u043e PostgreSQL. \u041e\u0447\u0435\u043d\u044c \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e, 313 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u043d\u0430 \u0430\u043d\u0433\u043b\u0438\u0439\u0441\u043a\u043e\u043c \u044f\u0437\u044b\u043a\u0435.<br \/>  \u0422\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u0436\u0435 \u043f\u043e\u0439\u0434\u0435\u043c \u0442\u0430\u043a\u0438\u043c \u043f\u0443\u0442\u0435\u043c:<\/p>\n<p>  <\/p>\n<ol>\n<li>\u041e\u0440\u0433\u0430\u043d\u0438\u0437\u0443\u0435\u043c \u0441\u0445\u043e\u0436\u0443\u044e \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u043f\u043b\u043e\u0449\u0430\u0434\u043a\u0443 \u0441\u0435\u0440\u0432\u0435\u0440\u043e\u0432 (\u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u043e\u043d\u043a\u0438 \u0431\u044b\u043b\u0430 \u0432\u044b\u0431\u0440\u0430\u043d\u0430 \u043d\u0430\u0448\u0430 \u00ab\u0440\u043e\u0434\u043d\u0430\u044f\u00bb RedOS 7.2 \u00ab\u041c\u0443\u0440\u043e\u043c\u00bb);<\/li>\n<li>\u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0432\u0441\u0435 \u00ab\u0441\u0445\u043e\u0436\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c\u00bb. \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0421\u0423\u0411\u0414 \u0432\u0437\u044f\u043b\u0438 \u0441\u0430\u043c\u0443\u044e \u0441\u0432\u0435\u0436\u0443\u044e \u043d\u0430 \u0441\u0435\u0433\u043e\u0434\u043d\u044f\u0448\u043d\u0438\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 PostgresPro Standard 13.<\/li>\n<\/ol>\n<p>  <\/p>\n<h2 id=\"plan-rabot\">\u041f\u043b\u0430\u043d \u0440\u0430\u0431\u043e\u0442<\/h2>\n<p>  <\/p>\n<p>\u0412\u0441\u0435 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e, \u043a\u0430\u043a \u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e:<\/p>\n<p>  <\/p>\n<ol>\n<li>\u0421\u0435\u0440\u0432\u0435\u0440\u0430 \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043b\u0438, \u0441\u043e\u0444\u0442 \u0442\u043e\u0436\u0435;<\/li>\n<li>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u0411\u0414 \u0432 PG, \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u043c \u043e\u0431\u044a\u0435\u043a\u0442\u044b, \u043f\u0435\u0440\u0435\u0433\u0440\u0443\u0436\u0430\u0435\u043c \u0434\u0430\u043d\u043d\u044b\u0435;<\/li>\n<li>\u0414\u043e\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c \u0431\u044d\u043a\u044d\u043d\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f;<\/li>\n<li>\u0424\u0440\u043e\u043d\u0442\u044d\u043d\u0434 \u043d\u0435 \u0442\u0440\u043e\u0433\u0430\u0435\u043c.<\/li>\n<li>\u0412\u0441\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442? \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u0432 \u0436\u0438\u0437\u043d\u0438 \u0432\u0441\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u043b\u043e\u0436\u043d\u0435\u0435.<\/li>\n<\/ol>\n<p>  <\/p>\n<h2 id=\"osobennosti-migriruemoy-bd\">\u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043c\u0438\u0433\u0440\u0438\u0440\u0443\u0435\u043c\u043e\u0439 \u0411\u0414<\/h2>\n<p>  <\/p>\n<p>\u041f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0443 \u043d\u0430\u0441, \u043a\u0430\u043a \u044f \u043d\u0430\u0437\u044b\u0432\u0430\u044e \u00abbackend-\u0446\u0435\u043d\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435\u00bb, \u0447\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442:<\/p>\n<p>  <\/p>\n<ol>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f ORM (hibernate);<\/li>\n<li>\u0412 \u0411\u0414 \u043d\u0435 \u0442\u0430\u043a \u043c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430 (\u043f\u043e\u0447\u0442\u0438 \u043d\u0435\u0442);<\/li>\n<li>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u0435 \u0442\u0430\u043a \u043c\u043d\u043e\u0433\u043e \u00ab\u0438\u0437\u044b\u0441\u043a\u043e\u0432\u00bb SQL, \u043a\u0430\u043a \u043c\u043e\u0433\u043b\u043e \u0431\u044b. \u0425\u043e\u0442\u044f, \u043a\u0430\u043a \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u043e\u0441\u044c, \u0442\u0430\u043a \u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u043d\u0430 \u043f\u0435\u0440\u0432\u044b\u0439 \u0432\u0437\u0433\u043b\u044f\u0434. \u0412\u043e\u043e\u0431\u0449\u0435, \u044f\u0437\u044b\u043a SQL \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0440\u043e\u0448\u043e \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d \u0438, \u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0431\u044b, \u0434\u043e\u043b\u0436\u0435\u043d \u00ab\u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u00bb \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043d\u0430 \u0432\u0441\u0435\u0445 \u0421\u0423\u0411\u0414, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u044f\u0432\u043b\u044f\u044e\u0442 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u044c \u0441\u043e \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043e\u043c SQL-XX (\u0437\u0434\u0435\u0441\u044c XX \u2013 \u044d\u0442\u043e \u0433\u043e\u0434 \u0432\u044b\u043f\u0443\u0441\u043a\u0430 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0430). \u0412 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0436\u0438\u0437\u043d\u0438 \u0432\u0441\u0435 \u0441\u043e\u0432\u0441\u0435\u043c \u0438\u043d\u0430\u0447\u0435, \u0440\u0430\u0437\u043d\u0438\u0446\u0443 \u0434\u0438\u0430\u043b\u0435\u043a\u0442\u043e\u0432 SQL \u043c\u043e\u0436\u043d\u043e (\u0448\u0443\u0442\u043b\u0438\u0432\u043e) \u043f\u0440\u043e\u0438\u043b\u043b\u044e\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u043e\u0439:<br \/>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/se\/a7\/5n\/sea75nk_psgqkytyudfwafymjrs.jpeg\"><\/li>\n<li>\u0412 \u043a\u043e\u0434\u0435 \u0432\u043f\u0435\u0440\u0435\u043c\u0435\u0436\u043a\u0443 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f \u00abnative SQL\u00bb \u0438 \u00abHibernate QL\u00bb. \u0422\u0430\u043a\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f QueryDSL.<\/li>\n<\/ol>\n<p>  <\/p>\n<h2 id=\"sozdanie-bd-pg\">\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0411\u0414 PG<\/h2>\n<p>  <\/p>\n<p>\u0420\u0430\u0437 \u0443\u0436 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 ora2pg, \u0442\u043e \u0438\u043c \u0438 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f. \u041d\u0430\u043f\u0438\u0441\u0430\u043d \u043e\u043d, \u043f\u043e\u0445\u043e\u0436\u0435, \u0430\u0436 \u043d\u0430 Perl\u2019\u0435, \u0447\u0442\u043e \u0432\u043f\u0440\u043e\u0447\u0435\u043c \u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u0440\u0442\u0438\u0442. \u0411\u044b\u043b\u0438 \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u043c\u0435\u043b\u043a\u0438\u0435 \u0437\u0430\u043c\u043e\u0440\u043e\u0447\u043a\u0438 \u0441 \u0435\u0433\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u043e\u0439, \u043d\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u043e\u043d \u0432\u043f\u043e\u043b\u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<br \/>  \u0411\u044b\u043b\u043e \u0440\u0435\u0448\u0435\u043d\u043e \u0441 \u0435\u0433\u043e \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0440\u0443\u043a\u0430\u043c\u0438. \u041f\u0430\u043a\u0435\u0442\u043e\u0432 \u0438 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440 \u2014 \u043c\u0438\u043d\u0438\u043c\u0443\u043c, \u0438\u0445 \u0442\u043e\u0436\u0435 \u0440\u0443\u043a\u0430\u043c\u0438.<br \/>  \u0412 \u0446\u0435\u043b\u043e\u043c \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u043e\u0442\u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0432\u043f\u043e\u043b\u043d\u0435 \u0434\u043e\u0441\u0442\u043e\u0439\u043d\u043e, \u0432\u044b\u0434\u0430\u0432 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u0441\u043a\u0440\u0438\u043f\u0442 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0442\u0430\u0431\u043b\u0438\u0446. \u0418\u0437 \u043c\u0438\u043d\u0443\u0441\u043e\u0432 \u2014 \u0432\u0441\u0435 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u044b\u0435 \u043a\u043b\u044e\u0447\u0438 \u043e\u043d \u043c\u043d\u0435 \u0441\u0434\u0435\u043b\u0430\u043b \u043a\u0430\u043a numeric(22), \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u044b\u0432\u0430\u0442\u044c \u043d\u0430 int8 (\u043e\u043d \u0436\u0435 bigint, \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043e\u043d \u0436\u0435 bigserial).<br \/>  \u0418 \u0432\u043e\u0442 \u0437\u0434\u0435\u0441\u044c \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u0430\u044f \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c. \u0421\u0442\u043e\u0438\u0442 \u043a\u0440\u0430\u0439\u043d\u0435 \u043f\u0440\u0438\u0441\u0442\u0430\u043b\u044c\u043d\u043e \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0442\u0438\u043f\u044b \u043f\u043e\u043b\u0435\u0439. \u041b\u0443\u0447\u0448\u0435 \u0434\u0430\u0436\u0435 \u0432\u043e\u043e\u0431\u0449\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u043f\u043e \u0442\u0438\u043f\u0430\u043c \u00ab\u0431\u044b\u043b\u043e\u00bb \u2014 \u00ab\u0441\u0442\u0430\u043b\u043e\u00bb \u0438 \u0435\u0435 \u043f\u0440\u0438\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c\u0441\u044f. \u041e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u044e\u0442 \u0441 number \u2014 float \u2014 numeric. \u0422\u0430\u043a\u0436\u0435 \u043d\u0430\u0434\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043d\u0438\u0446\u0443 \u0432 \u0434\u0430\u0442\u0430\u0445 \u2014 \u0432 Oracle \u0432 \u0434\u0430\u0442\u0435 \u0435\u0441\u0442\u044c \u0432\u0440\u0435\u043c\u044f, \u0432 pg \u043d\u0435\u0442. \u0414\u043e\u0441\u0442\u0443\u043f\u043d\u043e \u043f\u0440\u043e \u0442\u0438\u043f\u044b \u043e\u043f\u0438\u0441\u0430\u043d\u043e \u0437\u0434\u0435\u0441\u044c: <a href=\"https:\/\/habr.com\/ru\/post\/335716\/\">https:\/\/habr.com\/ru\/post\/335716\/<\/a><br \/>  \u0412\u0430\u0436\u043d\u044b\u0439 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 \u2014 \u0432\u0441\u0435\u043c \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u043c \u0443\u0441\u0442\u0440\u043e\u0438\u043b\u0438 \u0440\u0435\u0432\u0438\u0437\u0438\u044e, \u0442. \u0435. \u043a\u0430\u043a \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0432\u0441\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0431\u044b\u043b\u043e \u0440\u0435\u0448\u0435\u043d\u043e \u0441\u043d\u0430\u0431\u0434\u0438\u0442\u044c \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0435\u043c, \u0447\u0442\u043e \u044d\u0442\u043e \u0438 \u0437\u0430\u0447\u0435\u043c. \u0415\u0441\u043b\u0438 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f \u043d\u0435\u0442, \u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u043c\u044b \u043d\u0435 \u0437\u043d\u0430\u0435\u043c, \u0447\u0442\u043e \u044d\u0442\u043e \u0437\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 \u0438 \u043a\u0430\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f. \u042d\u0442\u0430 \u0440\u0430\u0431\u043e\u0442\u0430 \u0431\u044b\u043b\u0430 \u0441\u0434\u0435\u043b\u0430\u043d\u0430 \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 \u043b\u0438\u043d\u0435\u0439\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430.<br \/>  \u0422\u0430\u0431\u043b\u0438\u0446\u044b \u0441\u043e\u0437\u0434\u0430\u043b\u0438, \u043d\u0430\u0434\u043e \u043d\u0430\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0438\u0445 \u0434\u0430\u043d\u043d\u044b\u043c\u0438. \u041d\u0430\u043f\u043e\u043c\u043d\u044e, \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0436\u0438\u0432\u0430\u044f, \u043a\u0430\u0436\u0434\u044b\u0439 \u0434\u0435\u043d\u044c \u0432 \u043d\u0435\u0439 \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0434\u0430\u043d\u043d\u044b\u0435, \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0445 \u043f\u043e\u0442\u043e\u043a\u043e\u0432 \u0442\u0440\u0438 \u2014 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439, \u0440\u0430\u0441\u0447\u0435\u0442\u043d\u044b\u0439 \u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439 \u0432\u0432\u043e\u0434.<br \/>  \u0417\u0434\u0435\u0441\u044c \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u043b\u0438 \u0432\u0430\u0436\u043d\u044b\u043c \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u044e ora \u2192 pg, \u0447\u0442\u043e\u0431\u044b \u0432 \u043a\u0430\u0436\u0434\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0411\u0414 pg \u0431\u044b\u043b\u0430 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u0431\u043b\u0438\u0437\u043a\u0430 \u043a \u0411\u0414 ora (\u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u2014 \u0437\u043d\u0430\u0447\u0438\u0442 \u043a\u0430\u0436\u0434\u044b\u0439 \u0434\u0435\u043d\u044c). \u0422\u0430\u043a \u0440\u043e\u0434\u0438\u043b\u0441\u044f \u043c\u043e\u0434\u0443\u043b\u044c \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u0438.<\/p>\n<p>  <\/p>\n<h2 id=\"nastroyka-parametrov-proizvoditelnosti-subd\">\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0421\u0423\u0411\u0414<\/h2>\n<p>  <\/p>\n<p>\u0412\u043e\u043e\u0431\u0449\u0435 \u0433\u043e\u0432\u043e\u0440\u044f, \u0432\u0441\u0435 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0438 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438, \u043d\u043e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u0441\u0442\u043e\u0438\u0442 \u00ab\u043f\u043e\u0434\u043a\u0440\u0443\u0442\u0438\u0442\u044c\u00bb.<br \/>  \u041a\u043e\u043b\u043b\u0435\u0433\u0438 \u043f\u043e\u0441\u043e\u0432\u0435\u0442\u043e\u0432\u0430\u043b\u0438 \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u0442\u0430\u043a\u043e\u0439 \u0432\u043e\u0442 \u0441\u0438\u043c\u043f\u0430\u0442\u0438\u0447\u043d\u044b\u0439 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u0449\u0438\u043a \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432:<br \/>  <a href=\"https:\/\/pgtune.leopard.in.ua\/\">https:\/\/pgtune.leopard.in.ua\/<\/a>#\/ (PGTune \u2014 calculate configuration for PostgreSQL based on the maximum performance for a given hardware configuration).<br \/>  \u0411\u0443\u0434\u0435\u043c \u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c, \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c.<\/p>\n<p>  <\/p>\n<h2 id=\"pro-klaster\">\u041f\u0440\u043e \u043a\u043b\u0430\u0441\u0442\u0435\u0440<\/h2>\n<p>  <\/p>\n<p>\u0412 Oracle \u0443 \u043d\u0430\u0441 \u0431\u044b\u043b\u043e \u0434\u0432\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0411\u0414 (\u043e\u0442\u043a\u0430\u0437\u043e\u0443\u0441\u0442\u043e\u0439\u0447\u0438\u0432\u044b\u0439 \u043a\u043b\u0430\u0441\u0442\u0435\u0440), \u043f\u0440\u0438\u0447\u0435\u043c \u0432 \u044d\u0442\u043e\u0439 \u0421\u0423\u0411\u0414 \u0442\u0430\u043a\u043e\u0439 \u0440\u0435\u0436\u0438\u043c \u0440\u0430\u0431\u043e\u0442\u044b \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u00ab\u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438\u00bb. PG \u0432 \u044d\u0442\u043e\u043c \u043f\u043b\u0430\u043d\u0435, \u0441 \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u0442\u0430\u043a\u0438\u0445 \u0441\u0440\u0435\u0434\u0441\u0442\u0432 \u043d\u0435 \u0438\u043c\u0435\u0435\u0442, \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u2013 \u0431\u043e\u043b\u0435\u0435 \u0441\u0432\u043e\u0431\u043e\u0434\u0435\u043d \u0432 \u0432\u044b\u0431\u043e\u0440\u0435 \u0438\u043c\u0435\u044e\u0449\u0438\u0445\u0441\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u0439, \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0434\u043b\u044f \u043d\u0435\u0433\u043e. \u041f\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0435 \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0430 PG \u043c\u044b \u043e\u0431\u0440\u0430\u0442\u0438\u043b\u0438\u0441\u044c \u0437\u0430 \u043a\u043e\u043c\u043f\u0435\u0442\u0435\u043d\u0446\u0438\u044f\u043c\u0438 \u043a \u043e\u0434\u043d\u043e\u0439 \u0438\u0437 \u043d\u0430\u0448\u0438\u0445 \u043a\u043e\u043c\u0430\u043d\u0434, \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0432 \u0438\u0445 \u043a \u043f\u0440\u043e\u0435\u043a\u0442\u0443. \u0412 \u0438\u0442\u043e\u0433\u0435 \u0440\u043e\u0434\u0438\u043b\u043e\u0441\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 (\u043a\u043b\u0430\u0441\u0442\u0435\u0440 + \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043f\u043e \u0430\u0440\u0445\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e):<br \/>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/50\/do\/ac\/50doacmfhawuunfrochkjls1smo.png\"><\/p>\n<p>  <\/p>\n<h2 id=\"modul-replikacii\">\u041c\u043e\u0434\u0443\u043b\u044c \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u0438<\/h2>\n<p>  <\/p>\n<p>\u0418\u0442\u0430\u043a, \u0440\u0435\u0448\u0438\u043b\u0438 \u0434\u0435\u043b\u0430\u0442\u044c \u043c\u043e\u0434\u0443\u043b\u044c \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u0438. \u0415\u0441\u0442\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, SymmetricDS. \u041d\u043e \u043c\u044b \u0438\u043c \u0435\u0449\u0435 \u043d\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438\u0441\u044c, \u0430 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0435 \u0438 \u0442\u043e, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043d\u0430\u0441 \u0442\u043e\u0447\u043d\u043e \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043a \u0443\u0441\u043f\u0435\u0445\u0443. \u0418 \u0432 \u044d\u0442\u043e\u0442 \u0440\u0430\u0437 \u0440\u0435\u0448\u0438\u043b\u0438 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0433\u043e \u0440\u0443\u043a\u0430\u043c\u0438. \u0427\u0442\u043e\u0431\u044b \u0442\u043e\u0447\u043d\u043e \u0437\u043d\u0430\u0442\u044c, \u043a\u0430\u043a \u043e\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0438 \u043f\u0440\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u043e\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0435\u0433\u043e. \u0412 \u0438\u0442\u043e\u0433\u0435 \u043e\u043d \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u044b\u043c, \u043d\u043e \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u044b\u043c (\u0442\u0430\u043a\u0436\u0435 \u0434\u0443\u043c\u0430\u0435\u043c \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u0442\u044c \u2013 \u0432\u0434\u0440\u0443\u0433 \u043a\u043e\u043c\u0443-\u043d\u0438\u0431\u0443\u0434\u044c \u0435\u0449\u0435 \u043f\u043e\u043c\u043e\u0436\u0435\u0442).<br \/>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/gc\/kp\/m-\/gckpm-qqitqytysj8lkkm_fk3nm.png\"><br \/>  <em>\u041c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 \u043c\u043e\u0434\u0443\u043b\u044f \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u0438<\/em><\/p>\n<p>  <\/p>\n<p>\u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u043e \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u043c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0438 \u0434\u0432\u0443\u0445 \u0440\u0430\u0437\u043d\u044b\u0445 \u0411\u0414. \u041f\u043e \u043e\u043f\u044b\u0442\u0443 \u0440\u0430\u0431\u043e\u0442\u044b \u043c\u044b \u0431\u043e\u043b\u044c\u0448\u0435 \u00ab\u0442\u043e\u043f\u0438\u043c\u00bb \u0437\u0430 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c ETL \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043c\u043d\u043e\u0433\u043e (\u0438 \u043c\u043d\u043e\u0433\u0438\u0435 \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0438 \u0443\u043c\u0435\u0435\u043c) \u2014 Apache Airflow, NiFi, Talend, DataStage, Informatica. \u041d\u043e \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0442\u0430\u043a \u043a\u0430\u043a \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u044f \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043d\u043e\u0441\u0438\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0439 \u0445\u0430\u0440\u0430\u043a\u0442\u0435\u0440 \u2014 \u0440\u0435\u0448\u0438\u043b\u0438 \u0434\u0435\u043b\u0430\u0442\u044c \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e, \u0447\u0435\u0440\u0435\u0437 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 Oracle FDW. \u042d\u0442\u043e \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0438\u0437 \u0411\u0414 pg \u0441\u043e\u0435\u0434\u0438\u043d\u044f\u0442\u044c\u0441\u044f \u0441 \u0411\u0414 ora. \u0427\u0442\u043e \u0436, \u043d\u0430\u0447\u043d\u0435\u043c \u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c. \u0412 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0439 \u043f\u043e\u0441\u0442\u0430\u0432\u043a\u0435 pg \u044d\u0442\u043e\u0433\u043e \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u044f \u043d\u0435\u0442, \u0431\u0443\u0434\u0435\u043c \u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e. \u0414\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u2014 \u044d\u0442\u043e \u00ab\u043f\u043e-\u0432\u0437\u0440\u043e\u0441\u043b\u043e\u043c\u0443\u00bb, \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u044f \u0438\u0437 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u043e\u0432, \u0432\u0441\u0435 \u043a\u0430\u043a \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u0432 \u043c\u0438\u0440\u0435 linux.<br \/>  \u0412\u043e\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043e\u0441\u0430\u0434\u0430 \u2014 \u043d\u0435 \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043b\u043e\u0441\u044c. \u041d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043e\u043a\u043e\u0432\u044b\u0440\u044f\u0432 (\u043d\u0430 \u044d\u0442\u043e \u0443\u0448\u0435\u043b \u0434\u0435\u043d\u044c) \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u044f, \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0432\u0441\u0435 \u0436\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438\u0441\u044c, \u043d\u043e \u043a\u0430\u043a \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u0441\u044f \u00ab\u043e\u0441\u0430\u0434\u043e\u043a \u043e\u0441\u0442\u0430\u043b\u0441\u044f\u00bb, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u044f \u0432\u0437\u044f\u043b \u0438 \u0441\u043e\u0437\u0434\u0430\u043b \u0442\u0438\u043a\u0435\u0442 \u0432 \u0433\u0438\u0442\u0445\u0430\u0431\u0435 \u0430\u0432\u0442\u043e\u0440\u0443 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u044f. \u041d\u0435 \u0441\u0438\u043b\u044c\u043d\u043e \u043e\u0434\u043d\u0430\u043a\u043e, \u0432\u0435\u0440\u044f \u0432 \u0443\u0441\u043f\u0435\u0445, \u0442\u0430\u043a \u043a\u0430\u043a \u044d\u0442\u043e \u0437\u0432\u0443\u0447\u0430\u043b\u043e \u043a\u0430\u043a \u00ab\u043f\u043e\u043c\u043e\u0433\u0438\u0442\u0435 \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 \u043d\u0430 \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u043e\u0439 PostgresPro, \u043d\u0430 \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u043e\u0439 \u0436\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u043e\u043d\u043a\u0435 RedOS\u00bb (\u043a\u0430\u043a \u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0432\u0440\u044f\u0434 \u043b\u0438 \u043e\u043d\u0438 \u0432\u0441\u0435 \u044d\u0442\u043e \u0432\u0438\u0434\u0435\u043b\u0438), \u043e\u0434\u043d\u0430\u043a\u043e \u0436\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043e\u0442\u0440\u0435\u0430\u0433\u0438\u0440\u043e\u0432\u0430\u043b \u043c\u043e\u043b\u043d\u0438\u0435\u043d\u043e\u0441\u043d\u043e \u0438 \u0437\u0430 \u0434\u0435\u043d\u044c \u0432\u044b\u043f\u0443\u0441\u0442\u0438\u043b \u043d\u043e\u0432\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u043b\u0430\u0441\u044c \u0431\u0435\u0437 \u043f\u0440\u043e\u0431\u043b\u0435\u043c. \u042f \u0442\u0430\u043a \u0438 \u043d\u0435 \u043f\u043e\u043d\u044f\u043b, \u0447\u0442\u043e \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u2014 \u0442\u043e \u043b\u0438 \u043c\u044b \u043f\u043e\u0431\u0435\u0436\u0430\u043b\u0438 \u0432\u043f\u0435\u0440\u0435\u0434\u0438 \u043f\u0430\u0440\u043e\u0432\u043e\u0437\u0430 \u0438 Oracle FDW \u043d\u0430 13\u043c pg \u0435\u0449\u0435 \u043d\u0435 \u0441\u043e\u0431\u0438\u0440\u0430\u043b\u0438, \u0442\u043e \u043b\u0438 \u2026 \u041d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0438 \u0445\u043e\u0440\u043e\u0448\u043e (\u043a\u0430\u043a \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u043e\u0442\u043b\u0438\u0447\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442).<br \/>  \u0420\u0435\u043f\u043b\u0438\u043a\u0430\u0442\u043e\u0440. \u0420\u0435\u0448\u0438\u043b\u0438 \u0442\u0430\u043a \u2014 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u043a\u0430\u0436\u0434\u044b\u0439 \u0434\u0435\u043d\u044c \u043d\u043e\u0447\u044c\u044e, \u0440\u0435\u043f\u043b\u0438\u0446\u0438\u0440\u0443\u0435\u043c \u0434\u0432\u0443\u043c\u044f \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0430\u043c\u0438:<\/p>\n<p>  <\/p>\n<ol>\n<li>\u0418\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u0441\u043b\u043e\u0439 \u043a \u043d\u0430\u043c \u043f\u0440\u0438\u0435\u0437\u0436\u0430\u0435\u0442 \u00ab\u043d\u0430\u0431\u043e\u0440\u0430\u043c\u0438\u00bb \u0434\u0430\u043d\u043d\u044b\u0445, \u043a\u0430\u0436\u0434\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u043e\u043c\u0435\u0447\u0435\u043d \u0441\u0432\u043e\u0435\u043c \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u043e\u043c (shapshot_id). \u0422.\u0435. \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u0434\u0435\u043b\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u043e \u0432\u0441\u0442\u0430\u0432\u043a\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445. \u041b\u043e\u0433\u0438\u043a\u0443 \u043f\u043e\u0441\u0442\u0440\u043e\u0438\u043b\u0438 \u0442\u0430\u043a \u2014 \u0435\u0441\u043b\u0438 \u043d\u0430 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0435 \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u0441\u043d\u044d\u043f\u0448\u043e\u0442 \u2014 \u043f\u0435\u0440\u0435\u043b\u044c\u0435\u043c \u0435\u0433\u043e \u043a \u043d\u0430\u043c.<\/li>\n<li>\u0412\u0441\u0435 \u0434\u0440\u0443\u0433\u0438\u0435 \u0441\u043b\u043e\u0438 \u0440\u0435\u0448\u0438\u043b\u0438 \u043f\u0435\u0440\u0435\u043b\u0438\u0432\u0430\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 \u0446\u0435\u043b\u0438\u043a\u043e\u043c. \u041d\u0430 \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445 (\u0435\u0441\u043b\u0438 \u0432\u0441\u0442\u0440\u0435\u0442\u0438\u043c) \u0445\u043e\u0442\u0435\u043b\u0438 \u043f\u043e\u0434\u0443\u043c\u0430\u0442\u044c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e (\u043a\u0430\u043a \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c \u0434\u0435\u043b\u044c\u0442\u0443), \u043d\u043e \u0432 \u0438\u0442\u043e\u0433\u0435 \u043d\u0435 \u043f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b\u043e\u0441\u044c.<br \/>  \u0422\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0442\u043e\u0440 \u2014 \u044d\u0442\u043e \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u00ab\u0445\u043e\u0434\u044f\u0442\u00bb \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u00ab\u0441\u0432\u043e\u0438\u0445\u00bb \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445 \u0438 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044e\u0442 \u0438\u0445. \u0412 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445 \u0443\u043a\u0430\u0437\u0430\u043d\u044b \u043f\u0440\u0438\u0437\u043d\u0430\u043a\u0438, \u043a\u0430\u043a \u0438 \u0447\u0442\u043e \u0440\u0435\u043f\u043b\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u0442\u044c (\u0432\u043f\u043b\u043e\u0442\u044c \u0434\u043e \u0442\u0430\u0431\u043b\u0438\u0446, \u0448\u0430\u0431\u043b\u043e\u043d\u043e\u0432 insert \u0442\u0435\u043a\u0441\u0442\u043e\u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432).<br \/>  \u0420\u0435\u043f\u043b\u0438\u043a\u0430\u0442\u043e\u0440 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442 \u0437\u0430 2 \u0447\u0430\u0441\u0430, \u043f\u0438\u0448\u0435\u0442 \u043b\u043e\u0433\u0438, \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u00ab\u0431\u044b\u043b\u043e\u00bb \/ \u00ab\u0441\u0442\u0430\u043b\u043e\u00bb.<br \/>  \u041f\u043e\u0434\u043e\u0436\u0434\u0438\u0442\u0435, \u0430 \u043a\u0430\u043a \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0442\u043e\u0440? \u0412 pg (\u043d\u0430\u0448\u0435\u0439 \u0440\u0435\u0434\u0430\u043a\u0446\u0438\u0438) \u043d\u0435\u0442 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u043e\u0433\u043e \u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440\u0430 \u0434\u0436\u043e\u0431\u043e\u0432.<br \/>  \u041d\u0430 \u043f\u043e\u043c\u043e\u0449\u044c \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 pgCron. \u0424\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043d\u0430\u0441 \u0443\u0441\u0442\u0440\u043e\u0438\u043b\u0430, \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0432 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0435 \u0431\u044b\u043b\u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u044b \u0441 \u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0445\u043e\u0441\u0442\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0432 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u0445 \u0441\u0442\u0430\u0440\u0442\u0430 \u0434\u0436\u043e\u0431\u043e\u0432 (\u0442\u043e \u043b\u0438 localhost \u0435\u043c\u0443 \u043d\u0435 \u043f\u043e\u043d\u0440\u0430\u0432\u0438\u043b\u043e\u0441\u044c, \u0442\u043e \u043b\u0438 \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442 \u044f\u0432\u043d\u043e\u0435 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435 dns-\u0438\u043c\u0435\u043d\u0438 \u2014 \u043d\u043e \u043f\u043e\u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0432, \u0432\u0441\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c).<\/li>\n<\/ol>\n<p>  <\/p>\n<h2 id=\"dorabotka-prilozheniy\">\u0414\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439<\/h2>\n<p>  <\/p>\n<p>\u0412\u043e\u0442 \u043c\u044b \u0438 \u0434\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0434\u043e \u0434\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439. \u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0440\u0430\u0437\u0431\u0435\u0440\u0435\u043c\u0441\u044f, \u0433\u0434\u0435 \u0432 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f\u0445 \u043c\u0438\u0440\u0430 java \/ spring \u0436\u0438\u0432\u0443\u0442 sql \u0437\u0430\u043f\u0440\u043e\u0441\u044b.<\/p>\n<p>  <\/p>\n<ol>\n<li>\u0412 \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u0445 repository. \u041a\u0430\u043a \u0431\u044b\u043b\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043e \u0432\u044b\u0448\u0435, \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0431\u044b\u0432\u0430\u044e\u0442 \u00abnative\u00bb \u0438, \u043d\u0430\u0437\u043e\u0432\u0435\u043c \u0432 \u0440\u0438\u0444\u043c\u0443, \u00abhibernative\u00bb. \u0421\u0447\u0438\u0442\u0430\u0435\u043c, \u0447\u0442\u043e \u043f\u0435\u0440\u0432\u044b\u0435 \u043d\u0430\u0434\u043e \u0434\u043e\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c, \u0432\u0442\u043e\u0440\u044b\u0435 \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0435\u0442 (\u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0443\u0436\u043d\u043e);<\/li>\n<li>\u042f\u0432\u043d\u043e \u0432 \u043a\u043e\u0434\u0435 \u0434\u0440\u0443\u0433\u0438\u0445 \u043c\u043e\u0434\u0443\u043b\u0435\u0439. \u041e\u0431\u044b\u0447\u043d\u043e \u0442\u0430\u043a\u043e\u0433\u043e \u043d\u0435 \u0431\u044b\u0432\u0430\u0435\u0442, \u043d\u043e \u0438\u043d\u043e\u0433\u0434\u0430 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f;<\/li>\n<li>QueryDSL. \u0414\u0430, \u043e\u043d \u0443 \u043d\u0430\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f. \u0417\u0434\u0435\u0441\u044c \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u043d\u0435 \u043f\u0440\u043e \u0447\u0438\u0441\u0442\u044b\u0435 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0430 \u043f\u0440\u043e \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0438 \u0442\u0438\u043f\u044b \u0434\u0430\u043d\u043d\u044b\u0445, \u0442\u0430\u043c \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u044e\u0442\u0441\u044f OracleTemplate \u0438 \u0432\u0438\u0434\u0438\u043c\u043e \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0435 \u0441 \u044d\u0442\u0438\u043c \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438;<\/li>\n<li>\u041c\u043e\u0434\u0443\u043b\u044c \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u0438. \u041c\u043e\u0434\u0443\u043b\u044c \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u0438 \u0438\u043c\u0435\u0435\u0442 \u0441\u0432\u043e\u0439 xml \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u0447\u043d\u044b\u0439 \u0444\u0430\u0439\u043b, \u0433\u0434\u0435 \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u043d\u044b \u0432\u0441\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0438\u0437\u0432\u043b\u0435\u0447\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445. \u0418\u0437\u0432\u043b\u0435\u0447\u0435\u043d\u0438\u0435 \u0443 \u043d\u0430\u0441 \u043e\u0441\u043e\u0431\u043e \u043d\u0435 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f, \u043d\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u043d\u0430\u0434\u043e \u043f\u0435\u0440\u0435\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c.<\/li>\n<li>\u041c\u043e\u0434\u0443\u043b\u044c \u043e\u0442\u0447\u0435\u0442\u043d\u043e\u0441\u0442\u0438. \u0423 \u043d\u0435\u0433\u043e \u0442\u0430\u043a\u0436\u0435 \u0435\u0441\u0442\u044c \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u0447\u043d\u044b\u0439 \u0444\u0430\u0439\u043b yml \u0433\u0434\u0435 \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u043d\u044b SQL \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043e\u0442\u0447\u0435\u0442\u043e\u0432. \u042d\u0442\u043e, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435 \u0441\u0430\u043c\u044b\u0439 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0431\u043b\u043e\u043a, \u0442\u0430\u043a \u043a\u0430\u043a \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0437\u0434\u0435\u0441\u044c \u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u0441\u043b\u043e\u0436\u043d\u044b\u043c\u0438 \u0434\u043b\u044f \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u044f.<br \/>  \u0412 \u0438\u0442\u043e\u0433\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0434\u043e\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<br \/>  5.1. \u041f\u0440\u0438 \u0441\u0442\u0430\u0440\u0442\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442 \u2014 \u043e\u043d\u043e \u0437\u0430\u043f\u0443\u0449\u0435\u043d\u043e \u043f\u043e\u0434 ora \u0438\u043b\u0438 \u043f\u043e\u0434 pg? \u0421\u0434\u0435\u043b\u0430\u043b\u0438 \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0430\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u044f jdbc \u0441\u0442\u0440\u043e\u043a\u0443 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f. \u041f\u043e\u0432\u0435\u0437\u043b\u043e, \u0447\u0442\u043e \u0432\u0441\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u0447\u043d\u044b\u0435 \u0438 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u044b \u2014 \u0432 \u0444\u0438\u043b\u043e\u0441\u043e\u0444\u0438\u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u044d\u0442\u043e \u043d\u0435 \u0447\u0430\u0441\u0442\u044c \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0430 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f. \u0418 \u043f\u0440\u0438 \u0441\u0442\u0430\u0440\u0442\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u043e \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f, \u0433\u0434\u0435 \u043b\u0435\u0436\u0430\u0442 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u044b \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u0438\u043d\u0441\u0442\u0430\u043d\u0441\u0430.<br \/>  5.2. \u041c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0441\u0442\u0430\u0440\u0430\u0435\u043c\u0441\u044f \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u043c\u044b\u043c\u0438 \u043c\u0435\u0436\u0434\u0443 \u0431\u0430\u0437\u0430\u043c\u0438. \u0422\u0430\u043c \u0433\u0434\u0435 \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0442\u043e \u0440\u0430\u0437\u0432\u043e\u0434\u0438\u043c \u043a\u043e\u0434 \u044f\u0432\u043d\u043e (if (ora) { ora code } else { pg code });<\/li>\n<\/ol>\n<p>  <\/p>\n<p><strong>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u044b<\/strong><br \/>  \u041a\u0443\u0434\u0430 \u0431\u0435\u0437 \u043d\u0438\u0445.<br \/>  \u041d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u043c\u043d\u043e\u0433\u0438\u0445 \u0431\u0443\u0434\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043e\u0432\u0430\u0442\u044c, \u043a\u0430\u043a\u0438\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0440\u0435\u0448\u0430\u0442\u044c \u043a\u0440\u043e\u043c\u0435 \u0442\u0435\u0445, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0436\u0435 \u043e\u0431\u043e\u0437\u043d\u0430\u0447\u0435\u043d\u044b (\u0447\u0443\u0442\u044c \u0440\u0430\u043d\u0435\u0435 \u043f\u0440\u043e \u0442\u0438\u043f\u044b, \u043f\u0440\u043e \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0443 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0439).<br \/>  <strong>\u041f\u0435\u0440\u0432\u043e\u0439 \u0438 \u0441\u0430\u043c\u043e\u0439 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u043e\u0439 \u0441\u0442\u0430\u043b\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0441\u043e Spring Boot 1.5.<\/strong> \u041f\u043e \u043a\u0430\u043a\u0438\u043c \u0442\u043e \u043d\u0435\u0432\u0435\u0434\u043e\u043c\u044b\u043c \u043f\u0440\u0438\u0447\u0438\u043d\u0430\u043c \u043e\u043d \u043e\u0442\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u043f\u043e\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u0438\u043c\u044f \u0441\u0445\u0435\u043c\u044b \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u044b (\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441\u0430\u043c \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442, \u043d\u0435 native). \u0410 \u0442\u0430\u043a \u043a\u0430\u043a \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u0443 \u043d\u0430\u0441 \u0438\u0434\u0443\u0442 \u043a \u0440\u0430\u0437\u043d\u044b\u043c \u0441\u0445\u0435\u043c\u0430\u043c, \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u043e. \u0413\u0443\u0433\u043b \u043e\u0441\u043e\u0431\u043e \u043d\u0435 \u043f\u043e\u043c\u043e\u0433, \u043d\u043e \u043e\u0434\u043d\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438 \u2014 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 NamingStrategy, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0443\u0447\u0435\u0441\u0442\u044c \u044d\u0442\u0438 \u043d\u044e\u0430\u043d\u0441\u044b. \u0420\u0435\u0448\u0435\u043d\u0438\u0435 \u0431\u044b \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u043e, \u043d\u043e \u0440\u0435\u0448\u0438\u043b\u0438, \u0447\u0442\u043e \u044d\u0442\u043e \u043a\u043e\u0441\u0442\u044b\u043b\u044c \u0438 \u0440\u0435\u0448\u0438\u043b\u0438 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043d\u0430 Spring Boot 2.<br \/>  <strong>\u0417\u0430\u043f\u0443\u0441\u043a \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439 \u0443 \u043d\u0430\u0441 \u043e\u0444\u043e\u0440\u043c\u043b\u0435\u043d \u043a\u0430\u043a \u0441\u0435\u0440\u0432\u0438\u0441\u044b<\/strong> (systemctl), \u043f\u043e\u0447\u0435\u043c\u0443 \u0442\u043e \u043f\u043e\u0434 RHEL \u0437\u0430\u043f\u0443\u0441\u043a \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441\u0442\u0440\u043e\u043a\u043e\u0439 \u00abExecStart=\/path\/to\/spring_boot_based.jar\u00bb, \u0442\u043e\u0433\u0434\u0430 \u043a\u0430\u043a \u043f\u043e\u0434 RedOS \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u0435\u0441\u043b\u0438 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u00abExecStart=\/bin\/bash \/path\/to\/spring_boot_based.jar\u00bb.<br \/>  <strong>\u0412 pg \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0439 \u00ab\u043c\u043e\u0434\u043d\u044b\u0439\u00bb \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0442\u0438\u043f\u043e\u0432<\/strong> \u2014 \u0434\u0432\u043e\u0439\u043d\u043e\u0435 \u0434\u0432\u043e\u0435\u0442\u043e\u0447\u0438\u0435, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 1.23::int. \u041d\u043e \u0432\u043e\u0442 \u044d\u0442\u0438 \u0434\u0432\u043e\u0435\u0442\u043e\u0447\u0438\u044f \u043d\u0435 \u043b\u044e\u0431\u0438\u0442 hibernate, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442 \u0434\u0443\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u044d\u0442\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0437\u0430\u043f\u0440\u043e\u0441\u0430. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u2014 \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u0442\u0430\u0440\u044b\u0439 \u0434\u043e\u0431\u0440\u044b\u0439 cast(x as integer).<br \/>  \u0422\u0430\u043a\u0436\u0435 pg \u043d\u0430\u043c\u043d\u043e\u0433\u043e (\u043e\u0447\u0435\u043d\u044c \u043d\u0430\u043c\u043d\u043e\u0433\u043e) \u0431\u043e\u043b\u0435\u0435 \u0441\u0442\u0440\u043e\u0433\u043e \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043a \u0442\u0438\u043f\u0430\u043c \u0434\u0430\u043d\u043d\u044b\u0445. \u0418 \u0435\u0441\u0442\u044c \u0435\u0449\u0435 \u043e\u0434\u043d\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u00abnull \u0432 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u0445 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u00bb. \u0422.\u0435. \u0435\u0441\u043b\u0438 \u0443 \u043d\u0430\u0441 \u0432 Repository \u043f\u0440\u0438\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442 \u0437\u0430\u043f\u0440\u043e\u0441 \u00abselect * from some_function(parameters)\u00bb, \u0442\u043e \u043f\u0440\u0438 \u043f\u043e\u043f\u044b\u0442\u043a\u0435 \u0435\u0435 \u0432\u044b\u0437\u043e\u0432\u0430 pg \u043a\u0440\u043e\u043c\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442 \u043f\u0435\u0440\u0435\u0447\u0435\u043d\u044c \u0438 \u0442\u0438\u043f\u044b \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 (\u0432 pg \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u043f\u0435\u0440\u0435\u0433\u0440\u0443\u0436\u0435\u043d\u043d\u044b\u043c\u0438), \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u043d\u0443\u0436\u043d\u0443\u044e. Null \u0435\u0433\u043e \u0441\u0442\u0430\u0432\u0438\u0442 \u0432 \u0442\u0443\u043f\u0438\u043a, \u0442\u0430\u043a \u043a\u0430\u043a \u043e\u043d \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442 \u0435\u0433\u043e \u043a\u0430\u043a unknown. \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0442\u0443\u0442 \u0435\u0441\u0442\u044c \u043a\u0430\u043a\u043e\u0439-\u0442\u043e workaround, \u043d\u043e \u0441\u0445\u043e\u0434\u0443 \u043c\u044b \u0435\u0433\u043e \u043d\u0435 \u043d\u0430\u0448\u043b\u0438.<br \/>  <strong>\u041a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b<\/strong><br \/>  SQL \u044f\u0437\u044b\u043a \u0441\u0442\u0430\u0440\u044b\u0439, \u0440\u0430\u043d\u044c\u0448\u0435 \u0431\u044b\u043b\u043e \u00ab\u043d\u0435 \u043c\u043e\u0434\u043d\u043e\u00bb \u0440\u0430\u0437\u043b\u0438\u0447\u0430\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0438\u0435 \u0438 \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0438\u0435 \u0431\u0443\u043a\u0432\u044b, \u0442\u0430\u043a \u0447\u0442\u043e \u043e\u043d \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0440\u043e\u0434\u0438\u043b\u0441\u044f \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u043e\u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u043c. \u041f\u043e\u0442\u043e\u043c \u043a\u0442\u043e-\u0442\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043b, \u0447\u0442\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u0434\u0430\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u043d\u0435 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u043c\u0438 \u0438\u043c\u0435\u043d\u0430\u043c\u0438, \u0430 \u0445\u043e\u0442\u044c \u043a\u0430\u043a \u2014 \u0445\u043e\u0442\u044c \u043f\u043e-\u0440\u0443\u0441\u0441\u043a\u0438, \u0445\u043e\u0442\u044c \u0441 \u043f\u0440\u043e\u0431\u0435\u043b\u0430\u043c\u0438. \u0412\u043e\u0442 \u0442\u0430\u043a \u0438 \u0432\u043e\u0437\u043d\u0438\u043a\u043b\u0438 \u043a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 (\u0442. \u0435. \u0432 \u043a\u0430\u0432\u044b\u0447\u043a\u0430\u0445) \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b. \u0421\u043a\u043e\u043b\u044c\u043a\u043e \u0436 \u043e\u043d\u0438 \u043f\u0440\u0438\u0432\u043d\u043e\u0441\u044f\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u2026<br \/>  \u0422\u0430\u043a \u0432\u043e\u0442, \u0435\u0441\u043b\u0438 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 \u043d\u0435 \u043a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d, \u0442\u043e \u043e\u043d \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u043e\u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c. \u0415\u0441\u043b\u0438 \u043a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d, \u0442\u043e \u0434\u043e\u043b\u0436\u0435\u043d \u043f\u0438\u0441\u0430\u0442\u044c\u0441\u044f \u0432 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u0438.<br \/>  \u0412 Oracle \u2014 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0432\u0441\u0435 \u00ab\u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f\u00bb \u0431\u043e\u043b\u044c\u0448\u0438\u043c\u0438 \u0431\u0443\u043a\u0432\u0430\u043c\u0438. \u0412 pg \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442 \u2014 \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0438\u043c\u0438. \u0427\u0442\u043e \u0437\u0434\u0435\u0441\u044c \u0431\u044b\u043b\u043e \u0443 \u043d\u0430\u0441 \u2014 \u043c\u043e\u0434\u0443\u043b\u044c \u043e\u0442\u0447\u0435\u0442\u043d\u043e\u0441\u0442\u0438 (\u043e \u043d\u0435\u043c \u043d\u0438\u0436\u0435) \u0431\u044b\u043b \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043d \u043d\u0430 \u0442\u043e\u0447\u043d\u043e\u0435 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0435 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u043e\u0432 \u043a\u043e\u043b\u043e\u043d\u043e\u043a, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u043e \u0432\u0441\u0435\u0445 \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445 \u043e\u043d\u0438 \u0431\u044b\u043b\u0438 \u043a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u044b. \u041f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u044b\u0432\u0430\u0442\u044c, \u0443\u0447\u0438\u0442\u044c \u043c\u043e\u0434\u0443\u043b\u044c, \u0443\u0431\u0438\u0440\u0430\u0442\u044c \u043a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435. \u041c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0442\u0443\u0442 \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u00ab\u0437\u0430\u0440\u0435\u0437\u0435\u0440\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445\u00bb \u0441\u043b\u043e\u0432 \u0432 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f\u0445 \u043a\u043e\u043b\u043e\u043d\u043e\u043a (\u0434\u0430, \u044d\u0442\u043e \u043f\u043b\u043e\u0445\u043e, \u043d\u043e \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u00ab\u043d\u0430 \u0441\u0442\u0430\u0440\u0442\u0435\u00bb). \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u043c\u044b \u043f\u0438\u0448\u0435\u043c table.some_field. \u0422\u0443\u0442 \u0432\u0441\u0435 \u0445\u043e\u0440\u043e\u0448\u043e. \u0410 \u0435\u0441\u043b\u0438 table.type? \u0422\u0443\u0442 \u043f\u043b\u043e\u0445\u043e. \u0421\u043b\u043e\u0432\u043e type \u0437\u0430\u0440\u0435\u0437\u0435\u0440\u0432\u0438\u0440\u043e\u0432\u0430\u043d\u043e \u0438 \u0434\u0432\u0438\u0436\u043e\u043a \u0411\u0414, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432\u043e view \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u0430\u0435\u0442 \u044d\u0442\u043e \u0432 table.&quot;TYPE&quot; (\u0438\u043b\u0438 \u0432 table.&quot;type&quot; ?). \u0410 \u044d\u0442\u043e \u0443\u0436\u0435 \u2014 \u043a\u0432\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440. \u041f\u043e\u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u0443\u0439\u0442\u0435, \u044d\u0442\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e.<\/p>\n<p>  <\/p>\n<h2 id=\"modul-otchetnosti\">\u041c\u043e\u0434\u0443\u043b\u044c \u043e\u0442\u0447\u0435\u0442\u043d\u043e\u0441\u0442\u0438<\/h2>\n<p>  <\/p>\n<p>\u0424\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0435 \u043c\u0435\u0440\u0438\u043b\u043e \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0430 \u0438\u043d\u0442\u0435\u0433\u0440\u0430\u0446\u0438\u0438 \u2014 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u043e\u0441\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 \u043e\u0442\u0447\u0435\u0442\u0430\u0445. \u0421\u043a\u0440\u0438\u043f\u0442\u044b \u043e\u0442\u0447\u0435\u0442\u043e\u0432 \u0443 \u043d\u0430\u0441 \u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u0441\u043b\u043e\u0436\u043d\u044b\u043c\u0438, \u044d\u0442\u043e\u043c\u0443 \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u0441\u0432\u044f\u0449\u0435\u043d \u0432\u0435\u0441\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0440\u0430\u0437\u0434\u0435\u043b. \u0417\u0434\u0435\u0441\u044c \u0431\u044b\u043b\u043e \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u0434\u043e\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0432 \u00ab\u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0439 \u0432\u0438\u0434\u00bb, \u0447\u0442\u043e\u0431\u044b \u043e\u043d\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0438\u0441\u044c \u043d\u0430 \u043e\u0431\u043e\u0438\u0445 \u0431\u0430\u0437\u0430\u0445. \u0417\u0430\u0442\u0435\u043c \u0443\u0431\u0435\u0436\u0434\u0430\u0435\u043c\u0441\u044f, \u0447\u0442\u043e \u00ab\u043d\u043e\u0432\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b\u00bb \u0432\u044b\u0434\u0430\u044e\u0442 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u044b\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 (\u0440\u0430\u0432\u043d\u044b\u0439 \u0441\u0442\u0430\u0440\u043e\u043c\u0443) \u0438 \u043d\u0430 oracle \u0438 \u043d\u0430 pg. \u0412\u044b\u0432\u043e\u0434\u0438\u043c \u044d\u0442\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043d\u0430 \u043f\u0440\u043e\u0434 oracle \u2014 \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0442\u043e\u043c \u0431\u044b\u043b\u043e \u043b\u0435\u0433\u0447\u0435 \u043f\u0440\u0438 \u043e\u043a\u043e\u043d\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0439 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438.<br \/>  \u0410 \u043a\u0430\u043a \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u043e\u0442\u0447\u0435\u0442\u043e\u0432, \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0445 \u0438\u0437 \u0434\u0432\u0443\u0445 \u0431\u0430\u0437 \u0434\u0430\u043d\u043d\u044b\u0445? \u0424\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0442\u0447\u0435\u0442\u044b \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c (Excel), \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u043e\u0442\u0447\u0435\u0442\u043e\u0432 \u0434\u0440\u0443\u0433\u0438\u043c \u043a\u0430\u043a\u0438\u043c-\u043b\u0438\u0431\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c?\u2026 \u041c\u043e\u0436\u043d\u043e, \u043d\u043e \u0441\u043b\u043e\u0436\u043d\u043e\u0432\u0430\u0442\u043e. \u0410 \u0435\u0441\u043b\u0438 \u043c\u043d\u043e\u0433\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u0441\u0432\u0435\u0440\u043a\u0438 \u2014 \u0442\u043e \u0435\u0449\u0435 \u0431\u043e\u043b\u0435\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0432\u0430\u0442\u043e. \u041d\u0430\u0448\u043b\u0438 \u0441\u043f\u043e\u0441\u043e\u0431 \u043f\u0440\u043e\u0449\u0435 \u2014 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u00ab\u0441\u043b\u0435\u043f\u043a\u0438\u00bb \u043e\u0442\u0447\u0435\u0442\u043e\u0432 \u043d\u0430 \u043e\u0431\u043e\u0438\u0445 \u0441\u0442\u043e\u0440\u043e\u043d\u0430\u0445 (create table as select). \u041c\u043e\u0436\u043d\u043e \u0438 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c, \u0430 \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u044f. \u041f\u0435\u0440\u0435\u043b\u0438\u043b\u0438 \u043e\u0440\u0430\u043a\u043b\u043e\u0432\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0432 PG \u0447\u0435\u0440\u0435\u0437 fdw (\u043c\u043e\u0436\u043d\u043e \u0438 \u043d\u0435 \u043f\u0435\u0440\u0435\u043b\u0438\u0432\u0430\u0442\u044c, \u0430 \u0434\u0435\u043b\u0430\u0442\u044c \u00ab\u043d\u0430 \u0445\u043e\u0434\u0443\u00bb). \u0410 \u0434\u0430\u043b\u044c\u0448\u0435 \u0434\u0435\u043b\u043e \u0442\u0435\u0445\u043d\u0438\u043a\u0438 \u2014 select <em> from \u0442\u0430\u0431\u043b\u0438\u0446\u04301 except select <\/em> from \u0442\u0430\u0431\u043b\u0438\u0446\u04302. \u0414\u043e\u043b\u0436\u043d\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c\u0441\u044f \u043f\u0443\u0441\u0442\u043e\u0442\u0430, \u0435\u0441\u043b\u0438 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0430 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b. \u0415\u0441\u043b\u0438 \u0431\u0443\u0434\u0435\u0442\u0435 \u044d\u0442\u043e\u0442 \u0442\u0440\u044e\u043a \u0434\u0435\u043b\u0430\u0442\u044c \u0432 Oracle \u2014 \u0432\u043c\u0435\u0441\u0442\u043e except \u043d\u0430\u043f\u0438\u0448\u0438\u0442\u0435 minus. <\/p>\n<p>  <\/p>\n<h2 id=\"dorabotka-osobennostey-sql-zaprosov\">\u0414\u043e\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0435\u0439 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432<\/h2>\n<p>  <\/p>\n<p>\u0412\u043e\u0442 \u043c\u044b \u0438 \u0434\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0434\u043e \u0441\u0430\u043c\u043e\u0439 \u0433\u043b\u0430\u0432\u043d\u043e\u0439 \u0431\u043e\u043b\u0438. \u0412\u0440\u043e\u0434\u0435 \u0431\u044b SQL \u2014 \u044f\u0437\u044b\u043a \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439, \u043d\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0441\u0438\u043b\u044c\u043d\u043e \u0437\u0430\u0432\u0438\u0441\u0435\u0442\u044c \u043e\u0442 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0421\u0423\u0411\u0414 \u00ab\u0438 \u0432\u0441\u0435 \u0442\u0430\u043a\u043e\u0435\u00bb. \u041d\u043e \u043c\u044b \u0432\u0437\u0440\u043e\u0441\u043b\u044b\u0435 \u043b\u044e\u0434\u0438, \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u043c, \u0447\u0442\u043e \u044d\u0442\u043e \u043d\u0435\u043f\u0440\u0430\u0432\u0434\u0430. \u041e\u0431\u0440\u0430\u0449\u0430\u044e \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e \u043d\u0438\u0436\u0435\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0435 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043f\u0440\u0438\u0437\u043c\u0443 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0434\u043b\u044f \u0434\u0432\u0443\u0445 \u0411\u0414 (\u0442. \u0435. \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0438\u0435 \u0438 \u0442\u0430\u043c \u0438 \u0442\u0430\u043c).<br \/>  \u041d\u0430\u0447\u043d\u0435\u043c \u0441 \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e.<br \/>  \u041f\u0440\u0430\u0432\u0438\u043b\u043e, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c \u043d\u0430 \u0432\u0441\u044e \u0436\u0438\u0437\u043d\u044c: \u0432 Oracle null + some_text = some_text. \u041f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u043e \u0432\u0441\u0435\u0445 \u0434\u0440\u0443\u0433\u0438\u0445 \u0431\u0430\u0437\u0430\u0445 = null. Oracle \u043f\u0435\u0440\u0438\u043e\u0434\u0438\u0447\u0435\u0441\u043a\u0438 \u0437\u0430 \u044d\u0442\u043e \u0442\u0440\u043e\u043b\u043b\u044f\u0442:<br \/>  \u0422\u0430\u043a \u0431\u044b\u043b\u043e \u0432 \u0432\u0435\u0440\u0441\u0438\u0438 7, \u0437\u0430\u043c\u0435\u0442\u044c\u0442\u0435 \u0444\u0440\u0430\u0437\u0443 \u2014 &quot;\u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 Oracle7&quot;:<\/p>\n<p>  <\/p>\n<blockquote><p>The VARCHAR datatype is currently synonymous with the VARCHAR2 datatype. It is recommended that you use VARCHAR2 rather than VARCHAR. In a future version of Oracle7, VARCHAR might be a separate datatype used for variable length character strings compared with different comparison semantics.<\/p><\/blockquote>\n<p>\u0418, \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c 20 \u043b\u0435\u0442 \u0441\u043f\u0443\u0441\u0442\u044f, \u0432 \u0440\u0435\u043b\u0438\u0437\u0435 19c:<\/p>\n<p>  <\/p>\n<blockquote><p>Do not use the VARCHAR data type. Use the VARCHAR2 data type instead. Although the VARCHAR data type is currently synonymous with VARCHAR2, the VARCHAR data type is scheduled to be redefined as a separate data type used for variable-length character strings compared with different comparison semantics.<\/p><\/blockquote>\n<p>\u0421 \u044d\u0442\u0438\u043c \u0441\u0432\u044f\u0437\u0430\u043d \u043b\u044e\u0431\u043e\u043f\u044b\u0442\u043d\u044b\u0439 \u0442\u0440\u044e\u043a, \u043a\u0430\u043a \u043d\u0430\u043c \u0431\u0435\u0437\u043e\u0448\u0438\u0431\u043e\u0447\u043d\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u0432 \u043a\u0430\u043a\u043e\u0439 \u0431\u0430\u0437\u0435 \u043c\u044b \u043d\u0430\u0445\u043e\u0434\u0438\u043c\u0441\u044f, \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u043d\u0435 \u0437\u043d\u0430\u044f \u0432 \u043a\u0430\u043a\u043e\u0439 (\u043f\u0440\u0438 \u0443\u0441\u043b\u043e\u0432\u0438\u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u0432 PG \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u044f orafce):<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select coalesce(cast(null||'ora' as varchar(100)),'pg') db_type from dual<\/code><\/pre>\n<p>  <\/p>\n<p><strong>nvl<\/strong> \u2014 \u043f\u0440\u043e\u0441\u0442\u043e \u043c\u0435\u043d\u044f\u0435\u043c \u043d\u0430 coalesce \u043d\u0435 \u0434\u0443\u043c\u0430\u044f, \u0432\u0441\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<br \/>  <strong>decode<\/strong> \u2014 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0432\u043e\u0440\u0447\u0438\u043c \u043e \u043c\u043d\u043e\u0433\u043e\u0441\u043b\u043e\u0432\u043d\u043e\u0441\u0442\u0438, \u043d\u043e \u0432\u0441\u0435 \u0436\u0435 \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u044b\u0432\u0430\u0435\u043c \u0432 case.<br \/>  \u0427\u0443\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u0435\u0435. <strong>sysdate<\/strong>. \u041f\u043e\u043c\u043d\u0438\u043c, \u0447\u0442\u043e \u0443 Oracle \u2014 \u0432\u0440\u0435\u043c\u044f \u0435\u0441\u0442\u044c, \u0432 pg \u2014 \u043d\u0435\u0442. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u043b\u0438\u0431\u043e current_timestamp, \u043b\u0438\u0431\u043e current_date.<br \/>  <strong>rownum<\/strong>. \u041e\u0447\u0435\u043d\u044c \u043b\u044e\u0431\u044f\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043d\u0430 spring \u0445\u043e\u0442\u044c \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c \u043a\u043b\u044e\u0447. \u0427\u0430\u0441\u0442\u043e \u0434\u0435\u043b\u0430\u044e\u0442 &quot;\u0440\u043e\u0432\u043d\u0443\u043c&quot; \u2014 \u0442\u0430\u043a \u043a\u0430\u043a \u044d\u0442\u043e \u0434\u0435\u0448\u0435\u0432\u043e \u0438 \u0441\u0435\u0440\u0434\u0438\u0442\u043e. \u0427\u0435\u043c \u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u0432\u0435\u0442\u0438\u0442\u044c pg?<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">row_number() over ()<\/code><\/pre>\n<p>  <\/p>\n<p>\u0410 \u0432\u043e\u0442 Oracle \u043d\u0435 \u043f\u0443\u0441\u0442\u0438\u0442 \u0432\u0430\u043c over \u0441 \u043f\u0443\u0441\u0442\u044b\u043c\u0438 \u0441\u043a\u043e\u0431\u043a\u0430\u043c\u0438, \u0442\u0430\u043a \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c order by, \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0443\u044e \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0435 \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043a \u0442\u043e\u0440\u043c\u043e\u0437\u0430\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u0430.<br \/>  <strong>\u0410 \u0435\u0441\u043b\u0438 \u0443 \u043d\u0430\u0441 \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445 \u00abwhere rownum &lt; X\u00bb.<\/strong> \u041e\u0442\u0432\u0435\u0442 pg: limit. \u041d\u043e \u0432 Oracle \u043d\u0435 \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u041a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441 \u0434\u043b\u044f \u043e\u0431\u043e\u0438\u0445 \u0431\u0430\u0437: fetch next X rows only. \u041c\u0438\u043d\u0443\u0441 \u043a\u043e\u043c\u043f\u0440\u043e\u043c\u0438\u0441\u0441\u0430 \u2014 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445 (rownum \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, limit \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u0442\u043e\u0436\u0435 \u043d\u0435\u0442).<br \/>  <strong>Update.<\/strong> \u0410\u043f\u0434\u0435\u0439\u0442 \u00ab\u043d\u0435 \u043b\u044e\u0431\u0438\u0442 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435 \u0430\u043b\u0438\u0441\u0430 \u043f\u0440\u0438 \u043f\u0440\u0438\u0441\u0432\u043e\u0435\u043d\u0438\u0438\u00bb. \u0422.\u0435. update some_table t set t.some_field = \u2026 Oracle \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e, PG \u043d\u0435\u0442, \u0443\u0431\u0438\u0440\u0430\u0435\u043c \u0430\u043b\u0438\u0430\u0441\u044b. \u0421\u0432\u044f\u0437\u0430\u043d\u043e \u044d\u0442\u043e \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043f\u043e\u043b\u0435 \u0441 \u0430\u043b\u0438\u0430\u0441\u043e\u043c \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442\u0441\u044f \u043a\u0430\u043a \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0438 \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0432 \u043f\u0440\u0430\u0432\u043e\u0439 \u0447\u0430\u0441\u0442\u0438, \u043d\u043e \u043f\u0440\u0438 \u043f\u0440\u0438\u0441\u0432\u0430\u0438\u0432\u0430\u043d\u0438\u0438 \u2014 PG \u043d\u0430\u0441\u0442\u0430\u0438\u0432\u0430\u0435\u0442 \u043d\u0430 \u0433\u043e\u043b\u043e\u043c \u043f\u043e\u043b\u0435. \u041d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c, \u0447\u0442\u043e \u0443 PG \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0439 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u00abupdate from join\u00bb, \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0432\u0441\u0435\u0433\u0434\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u2014 \u0438\u043d\u0430\u0447\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0441 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c\u044e.<br \/>  <strong>\u0418\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u044b.<\/strong> PG \u043d\u0435 \u043b\u044e\u0431\u0438\u0442 \u0431\u0435\u0437\u044b\u043c\u044f\u043d\u043d\u044b\u0435 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 select * from (select \u2026). \u041d\u0443\u0436\u043d\u043e \u00ab\u0430\u043b\u0438\u0430\u0441\u0438\u0442\u044c\u00bb \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441. \u041d\u043e where x in (select \u2026) \u0432\u043f\u043e\u043b\u043d\u0435 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e, \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u0430\u043b\u0438\u0430\u0441 \u043d\u0435 \u043d\u0443\u0436\u0435\u043d.<br \/>  <strong>Group by 1,2,3.<\/strong> \u042d\u0442\u043e \u043d\u0435 \u043d\u0430 \u0442\u0435\u043c\u0443 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438, \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u043c\u0435\u0447\u0443 \u2014 \u044d\u0442\u043e \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0444\u0438\u0447\u0430 PG, \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043d\u0435\u0442 \u0432 Oracle. \u041d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0430\u0437\u044b \u0442\u043e\u0436\u0435 \u0435\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u044e\u0442 (firebird \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440). \u042d\u0442\u043e \u043c\u0435\u0433\u0430\u0443\u0434\u043e\u0431\u043d\u043e.<br \/>  <strong>\u0424\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439.<\/strong> \u0427\u0442\u043e \u0443 \u043d\u0430\u0441 \u0444\u043e\u0440\u043c\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439? \u041e\u043d\u043e \u0435\u0441\u0442\u044c, \u043d\u043e \u043e\u043d\u043e \u0440\u0430\u0437\u043d\u043e\u0435 \u0438 \u0442\u0430\u043c, \u0438 \u0442\u0430\u043c. \u041d\u043e \u043d\u0430\u043c \u043f\u043e \u0438\u0434\u0435\u0435 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043d\u0430\u0434\u043e \u2014 \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u0447\u0438\u0441\u043b\u043e \u0441 \u0434\u0432\u0443\u043c\u044f \u0437\u043d\u0430\u043a\u0430\u043c\u0438 \u043f\u043e\u0441\u043b\u0435 \u0437\u0430\u043f\u044f\u0442\u043e\u0439, \u043f\u0440\u0438\u0447\u0435\u043c \u0435\u0441\u043b\u0438 \u0447\u0438\u0441\u043b\u043e \u0446\u0435\u043b\u043e\u0435, \u0442\u043e \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u0431\u0435\u0437 \u0437\u043d\u0430\u043a\u043e\u0432. \u042d\u0442\u043e \u0443 \u043d\u0430\u0441 \u043f\u043e\u043b\u0435 \u00ab\u043f\u0440\u043e\u043f\u0443\u0441\u043a\u043d\u0430\u044f \u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0441\u0442\u044c\u00bb, \u0442. \u0435. \u041c\u044b \u0435\u0435 \u0445\u043e\u0442\u0438\u043c \u0432\u044b\u0432\u0435\u0441\u0442\u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u00ab2 \u041c\u0431\u0438\u0442\/\u0441\u00bb. \u041f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0432\u043e\u0442 \u0442\u0430\u043a: <\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">coalesce(to_char(round(cast(some_field as numeric(38, 8)), 2))<\/code><\/pre>\n<p>  <\/p>\n<p>\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0432 Oracle \u0440\u0430\u0437\u0434\u0435\u043b\u0438\u0442\u0435\u043b\u044c \u2014 \u0437\u0430\u043f\u044f\u0442\u0430\u044f, \u0432 PG \u2014 \u0442\u043e\u0447\u043a\u0430. \u041d\u043e \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043f\u0440\u0438\u0435\u043c\u043b\u0435\u043c\u043e (\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u0447\u0435\u0440\u0435\u0437 nls \u044d\u0442\u043e \u0442\u043e\u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u0434\u043e\u0440\u0435\u0448\u0438\u0442\u044c).<br \/>  <strong>\u041f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 (sequence). <\/strong><br \/>  \u0410 \u0432\u043e\u0442 \u0442\u0443\u0442 \u043d\u0430\u0441 \u0436\u0434\u0430\u043b\u043e \u0440\u0430\u0437\u043e\u0447\u0430\u0440\u043e\u0432\u0430\u043d\u0438\u0435. \u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0439 \u0438 \u043a \u0435\u0434\u0438\u043d\u043e\u043c\u0443 \u0435\u0433\u043e \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c. \u041b\u0430\u0434\u043d\u043e \u0445\u043e\u0442\u044c \u043d\u0435 \u0442\u0430\u043a \u0447\u0430\u0441\u0442\u043e \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f \u044f\u0432\u043d\u044b\u0439 \u0432\u044b\u0437\u043e\u0432 \u0441\u0438\u043a\u0432\u0435\u043d\u0441\u043e\u0432.<br \/>  \u0421\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 <\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">Ora: select sequence.nextval from dual Pg: select nextval(\u2018sequence\u2019)<\/code><\/pre>\n<p>  <\/p>\n<h2 id=\"slozhnye-funkcii\">\u0421\u043b\u043e\u0436\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438<\/h2>\n<p>  <\/p>\n<p>\u041d\u0430\u0448\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043f\u0435\u0441\u0442\u0440\u044f\u0442 \u0441\u043b\u043e\u0436\u043d\u044b\u043c\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u043c\u0438 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0434\u0430\u0442\u0430\u043c\u0438 \u2014 \u044d\u0442\u043e \u0438 \u0438\u0437\u0432\u043b\u0435\u0447\u0435\u043d\u0438\u044f \u043d\u043e\u043c\u0435\u0440\u0430 \u0434\u043d\u044f \u0432 \u0433\u043e\u0434\u0443 \u0438\u0437 \u0434\u0430\u0442\u044b, \u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u043c\u0435\u0436\u0434\u0443 \u0434\u0432\u0443\u043c\u044f \u0434\u0430\u0442\u0430\u043c\u0438. \u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u043c\u044b \u043f\u0440\u0438\u0443\u043d\u044b\u043b\u0438 \u0438 \u043f\u043e\u0434\u0443\u043c\u0430\u043b\u0438, \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u043e \u0430\u043d\u0430\u043b\u043e\u0433\u0438 \u043e\u0440\u0430\u043a\u043b\u043e\u0432\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u0437\u0430\u043c\u0435\u043d\u0438\u0432 \u0432\u0441\u0435 \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445 \u0438\u043c\u0438 (\u0442\u0430\u043a \u043a\u0430\u043a \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u044d\u0442\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0441\u0438\u043b\u044c\u043d\u043e \u0440\u0430\u0437\u043b\u0438\u0447\u0435\u043d \u0432 \u044d\u0442\u0438\u0445 \u0421\u0423\u0411\u0414). \u0410 \u0432 \u043e\u0440\u0430\u043a\u043b\u0435, \u0435\u0441\u043b\u0438 \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f, \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a\u0438\u0435 \u0436\u0435 \u00ab\u0437\u0430\u0433\u043b\u0443\u0448\u043a\u0438\u00bb, \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0449\u0438\u0435 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438.<br \/>  \u0414\u0430\u0436\u0435 \u043d\u0430\u0447\u0430\u043b\u0438 \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u0442\u044c, \u043d\u043e \u0437\u0430\u0448\u043b\u0438 \u0432 \u0442\u0443\u043f\u0438\u043a. \u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043a\u0430\u043a \u00ab\u0438\u0437\u044f\u0449\u043d\u043e\u00bb \u0432 \u043e\u0440\u0430\u043a\u043b\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u044f months_between:<\/p>\n<p>  <\/p>\n<blockquote><p>MONTHS_BETWEEN returns number of months between dates date1 and date2. If date1 is later than date2, then the result is positive. If date1 is earlier than date2, then the result is negative. If date1 and date2 are either the same days of the month or both last days of months, then the result is always an integer. Otherwise Oracle Database calculates the fractional portion of the result based on a 31-day month and considers the difference in time components date1 and date2.<\/p><\/blockquote>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0442\u044c \u0442\u0430\u043a\u0438\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e \u2014 \u043c\u043e\u0436\u043d\u043e \u0441\u0447\u0438\u0442\u0430\u0442\u044c \u044d\u0442\u043e \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u043c.<br \/>  \u0412\u043e\u0432\u0440\u0435\u043c\u044f \u043f\u043e\u043f\u0430\u043b\u043e\u0441\u044c \u043d\u0430 \u0433\u043b\u0430\u0437\u0430 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 orafce \u2014 \u00abOracle&#8217;s compatibility functions and packages\u00bb, \u00abThis module allows use a well known Oracle&#8217;s functions and packages inside PostgreSQL\u00bb. \u041c\u043e\u0436\u043d\u043e \u0434\u0430\u0436\u0435 \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e \u043e\u043d\u043e \u043d\u0430\u0441 \u0432 \u043a\u0430\u043a\u043e\u0439 \u0442\u043e \u043c\u0435\u0440\u0435 \u0438 \u0441\u043f\u0430\u0441\u043b\u043e.<br \/>  \u041d\u0435 \u043e\u0431\u043e\u0448\u043b\u043e\u0441\u044c \u0431\u0435\u0437 \u043b\u043e\u0436\u043a\u0438 \u0434\u0435\u0433\u0442\u044f \u2014 100% \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438 \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0435\u0442, \u043c\u044b \u0436\u0435 \u043f\u043e\u043c\u043d\u0438\u043c, \u0447\u0442\u043e pg \u0431\u043e\u043b\u0435\u0435 \u0441\u0442\u0440\u043e\u0433 \u0432 \u0442\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u0438? \u041a\u0430\u043a\u0438\u0435-\u0442\u043e \u0438\u0437 \u044d\u0442\u0438\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0432 Oracle \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u044e\u0442 \u043d\u0430 \u0432\u0445\u043e\u0434 \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u0430\u0442\u0443, \u0430 \u0435\u0449\u0435 \u0438 timestamp, \u0432 pg \u0442\u0430\u043a\u0430\u044f \u0444\u0438\u0448\u043a\u0430 \u043d\u0435 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442. \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435 \u044d\u0442\u043e \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 \u0441\u0442\u0430\u043b\u043e \u0434\u043b\u044f \u043d\u0430\u0441 must have. \u041e\u043d\u043e \u0434\u0430\u0436\u0435 \u0442\u0430\u0431\u043b\u0438\u0447\u043a\u0443 dual \u044d\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442.<br \/>  \u0418\u0434\u0435\u043c \u0434\u0430\u043b\u044c\u0448\u0435, \u043b\u044e\u0431\u043e\u043f\u044b\u0442\u043d\u043e\u0435 \u2014 <strong>greatest<\/strong> \u0438 <strong>least<\/strong>. \u0412\u043b\u044f\u043f\u0430\u043b\u0438\u0441\u044c, \u0447\u0438\u0442\u0430\u0435\u043c \u0443 PG:<\/p>\n<p>  <\/p>\n<blockquote><p>\u0417\u0430\u043c\u0435\u0442\u044c\u0442\u0435, \u0447\u0442\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u0438 GREATEST \u0438 LEAST \u043d\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u044b \u0432 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0435 SQL, \u043d\u043e \u0447\u0430\u0441\u0442\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u044e\u0442\u0441\u044f \u0432 \u0421\u0423\u0411\u0414 \u043a\u0430\u043a \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u044f. \u0412 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0434\u0440\u0443\u0433\u0438\u0445 \u0421\u0423\u0411\u0414 \u043e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0442\u044c NULL, \u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0432\u0441\u0435, \u0430 \u043b\u044e\u0431\u043e\u0439 \u0438\u0437 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0440\u0430\u0432\u0435\u043d NULL.<\/p><\/blockquote>\n<p>\u041e\u0447\u0435\u043d\u044c \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u043c, \u043a\u0430\u043a\u0438\u0435 \u0442\u0430\u043a\u0438\u0435 \u00ab\u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435\u00bb \u0421\u0423\u0411\u0414 \u0432\u044b \u0438\u043c\u0435\u043b\u0438 \u0432\u0432\u0438\u0434\u0443.<\/p>\n<p>  <\/p>\n<p><strong>\u0412\u0435\u043b\u0438\u043a\u0438\u0439 \u0438 \u0443\u0436\u0430\u0441\u043d\u044b\u0439 Number<\/strong><br \/>  \u0421\u0430\u043c\u044b\u0439 \u043b\u0443\u0447\u0448\u0438\u0439 \u0442\u0438\u043f \u0432 Oracle. \u0415\u0441\u043b\u0438 \u043d\u0435 \u0437\u043d\u0430\u0435\u0448\u044c \u0444\u043e\u0440\u043c\u0430\u0442 \u0438 \u0442\u0438\u043f \u0447\u0438\u0441\u043b\u0430 \u2014 \u00ab\u043b\u0435\u043f\u0438\u00bb \u0432\u0441\u0435\u0433\u0434\u0430 number. \u0418 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0435 \u0432\u043b\u0435\u0437\u0435\u0442.<br \/>  \u0410 \u0447\u0442\u043e \u043d\u0430\u043c \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0438\u0442\u044c pg? Pg \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0438\u0442\u044c numeric, \u0432 Oracle \u043e\u043d \u0442\u043e\u0436\u0435 \u0435\u0441\u0442\u044c.<br \/>  \u0418 number \u0438 numeric \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0432 \u0442\u0440\u0435\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u0445:<br \/>  numeric(x,y); numeric(x); numeric.<br \/>  \u041f\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u043e\u0431 \u044d\u0442\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438. \u041d\u043e, \u043a\u0430\u043a \u043f\u0435\u043b \u043a\u043e\u0433\u0434\u0430-\u0442\u043e \u0421\u0435\u0440\u0433\u0435\u0439 \u0428\u043d\u0443\u0440\u043e\u0432, \u0435\u0441\u0442\u044c \u043e\u0434\u0438\u043d \u043d\u044e\u0430\u043d\u0441, \u043e\u043d \u0443 \u043d\u0430\u0441 \u0432 \u044d\u0442\u043e\u0442 \u0440\u0430\u0437 \u0436\u0438\u0432\u0435\u0442 \u0432 PG:<\/p>\n<p>  <\/p>\n<blockquote><p>\u0431\u0435\u0437 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u044f \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u0438 \u0438 \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0441\u0442\u043e\u043b\u0431\u0435\u0446, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0442\u044c \u0447\u0438\u0441\u043b\u043e\u0432\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043b\u044e\u0431\u043e\u0439 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u0438 \u0438 \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u043c\u044b\u0445 \u0441\u0438\u0441\u0442\u0435\u043c\u043e\u0439. \u0412 \u0441\u0442\u043e\u043b\u0431\u0446\u0435 \u044d\u0442\u043e\u0433\u043e \u0442\u0438\u043f\u0430 \u0432\u0445\u043e\u0434\u043d\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043d\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u043a \u043a\u0430\u043a\u043e\u043c\u0443-\u043b\u0438\u0431\u043e \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0443, \u0442\u043e\u0433\u0434\u0430 \u043a\u0430\u043a \u0432 \u0441\u0442\u043e\u043b\u0431\u0446\u0430\u0445 numeric \u0441 \u044f\u0432\u043d\u043e \u0437\u0430\u0434\u0430\u043d\u043d\u044b\u043c \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u043e\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u043e\u0434\u0433\u043e\u043d\u044f\u044e\u0442\u0441\u044f \u043f\u043e\u0434 \u044d\u0442\u043e\u0442 \u043c\u0430\u0441\u0448\u0442\u0430\u0431. (\u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442 SQL \u0443\u0442\u0432\u0435\u0440\u0436\u0434\u0430\u0435\u0442, \u0447\u0442\u043e \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0434\u043e\u043b\u0436\u0435\u043d \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431 0, \u0442. \u0435. \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442\u044c\u0441\u044f \u043a \u0446\u0435\u043b\u044b\u043c \u0447\u0438\u0441\u043b\u0430\u043c. \u041e\u0434\u043d\u0430\u043a\u043e \u043c\u044b \u0441\u0447\u0438\u0442\u0430\u0435\u043c \u044d\u0442\u043e \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u043c. \u0415\u0441\u043b\u0438 \u0434\u043b\u044f \u0432\u0430\u0441 \u0432\u0430\u0436\u043d\u0430 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u043c\u043e\u0441\u0442\u044c, \u0432\u0441\u0435\u0433\u0434\u0430 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0439\u0442\u0435 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c \u0438 \u043c\u0430\u0441\u0448\u0442\u0430\u0431 \u044f\u0432\u043d\u043e.)<\/p><\/blockquote>\n<p>\u0412\u044b \u0442\u043e, \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c, \u0438 \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0435, \u0430 \u043d\u0430\u043c \u0442\u043e \u043a\u0430\u043a \u0431\u044b\u0442\u044c? \u0422.\u0435. numeric \u0432 PG \u0432\u0435\u0434\u0435\u0442 \u0441\u0435\u0431\u044f \u043f\u043e\u0445\u043e\u0436\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c number\u2019\u0443 \u0432 Oracle, \u043d\u043e \u0441\u0430\u043c numeric \u0432 Oracle \u2014 \u0432\u0435\u0434\u0435\u0442 \u0441\u0435\u0431\u044f \u043f\u043e \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0443.<br \/>  \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 select cast(1.2345 as numeric) from dual \u0432 \u0440\u0430\u0437\u043d\u044b\u0445 \u0431\u0430\u0437\u0430\u0445, \u043f\u043e\u0447\u0443\u0432\u0441\u0442\u0432\u0443\u0439\u0442\u0435 \u0440\u0430\u0437\u043d\u0438\u0446\u0443.<br \/>  \u0422\u0430\u043a \u0447\u0442\u043e \u0431\u0443\u0434\u0435\u043c \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u044f\u0432\u043d\u043e, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 numeric(38,8).<br \/>  \u0412\u043e\u0442 \u0435\u0449\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e. \u0412 \u043e\u0434\u043d\u043e\u043c \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u0435 \u0443 \u043d\u0430\u0441 \u0431\u044b\u043b \u043f\u043e\u0434\u0441\u0447\u0435\u0442 \u0447\u0438\u0441\u043b\u0430 \u0441\u0442\u0440\u043e\u043a (count), \u0432 \u0435\u0433\u043e \u0433\u043e\u043b\u043e\u0432\u043d\u043e\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u0435 \u0431\u044b\u043b \u0440\u0430\u0441\u0447\u0435\u0442:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">ROUND((cast(count as numeric(38,8)) \/ cast(first_value(count) OVER (partition by CODE_RUS, BS ORDER BY count DESC) as numeric(38,8))) * 100, 2) AS PERCENTAGE<\/code><\/pre>\n<p>  <\/p>\n<p>\u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0437\u0430\u043f\u0440\u043e\u0441 \u0431\u044b\u043b \u0431\u0435\u0437 \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u0432 numeric(38,8) (\u0442. \u0435. \u00ab\u043a\u0430\u043a \u0435\u0441\u0442\u044c\u00bb) \u0438 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b \u043f\u043e \u0440\u0430\u0437\u043d\u043e\u043c\u0443: Oracle \u0434\u0435\u043b\u0438\u043b \u043e\u0434\u043d\u043e \u043d\u0430 \u0434\u0440\u0443\u0433\u043e\u0435 \u043a\u0430\u043a \u0432\u0435\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 \u0447\u0438\u0441\u043b\u0430, PG \u0432\u043e\u0441\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u043b \u0438\u0445 \u043a\u0430\u043a \u0446\u0435\u043b\u044b\u0435.<br \/>  \u0411\u044b\u043b\u0438 \u0435\u0449\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b (\u0442\u0430\u043a \u0434\u043e \u043a\u043e\u043d\u0446\u0430 \u0438 \u043d\u0435 \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0432 \u0444\u0438\u0437\u0438\u043a\u0435 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430), \u043a\u043e\u0433\u0434\u0430 \u0432 \u043e\u0434\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435 Oracle \u043e\u043a\u0440\u0443\u0433\u043b\u0438\u043b 87.5 \u043a 88, \u0430 \u0432 \u0434\u0440\u0443\u0433\u043e\u043c \u0443\u0436\u0435 \u043a 87.<br \/>  <strong>\u0417\u0430\u0441\u0430\u0434\u0430 \u0441 Boolean<\/strong><br \/>  \u041e\u0447\u0435\u0440\u0435\u0434\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0430 \u0442\u0440\u0443\u0434\u043e\u0437\u0430\u0442\u0440\u0430\u0442. \u041b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043f\u043e\u043b\u044f \u0432 Oracle \u0431\u044b\u043b\u0438 \u0437\u0430\u0432\u0435\u0434\u0435\u043d\u044b \u043a\u0430\u043a NUMBER(1), \u0432 \u042f\u0432\u0435\/\u041a\u043e\u0442\u043b\u0438\u043d\u0435\/\u0425\u0438\u0431\u0435\u0440\u043d\u0435\u0439\u0442\u0435 \u043e\u0431\u044a\u044f\u0432\u043b\u0435\u043d\u044b \u043a\u0430\u043a Boolean. \u041f\u0440\u0438 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0430\u0446\u0438\u0438 \u0432 PG \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u0438\u0445 int2, \u043d\u043e \u043d\u0435 \u0442\u0443\u0442-\u0442\u043e \u0431\u044b\u043b\u043e. \u0415\u0441\u043b\u0438 Oracle \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e \u00ab\u043a\u0430\u0441\u0442\u0438\u0442\u00bb true \u0432 number(1), \u0442\u043e PG \u0437\u0434\u0435\u0441\u044c \u043a\u0443\u0434\u0430 \u043a\u0430\u043a \u0431\u043e\u043b\u0435\u0435 \u0449\u0435\u043f\u0435\u0442\u0438\u043b\u0435\u043d. \u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u2014 \u0432\u043e\u0442 \u0442\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select count(*) from some_table where boolean_field<\/code><\/pre>\n<p>  <\/p>\n<p>\u0418 \u0442\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select count(*) from some_table where boolean_field = '1'<\/code><\/pre>\n<p>  <\/p>\n<p>\u0410 \u0442\u0430\u043a \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select count(*) from some_table where boolean_field = 1<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u044b\u0432\u043e\u0434: \u043c\u0435\u043d\u044f\u0435\u043c \u0432 PG \u0432\u0441\u0435 \u043d\u0430 \u044f\u0432\u043d\u044b\u0439 Boolean, \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u044b\u0432\u0430\u0435\u043c \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u0441\u0432\u044f\u0437\u0438, \u0440\u0435\u043f\u043b\u0438\u043a\u0430\u0446\u0438\u0438.<br \/>  \u041e\u0447\u0435\u043d\u044c \u0441\u043f\u0430\u0441\u0430\u0435\u0442 \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">ALTER TABLE table ALTER COLUMN field1 TYPE boolean USING CASE WHEN field1 = 0 THEN FALSE WHEN field1 = 1 THEN TRUE ELSE NULL END;<\/code><\/pre>\n<p>  <\/p>\n<p>Hibernate \u0442\u043e\u0436\u0435 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u0442\u0440\u0430\u043d\u043d\u043e\u0441\u0442\u0435\u0439:<\/p>\n<p>  <\/p>\n<pre><code class=\"java\">Session.createQuery(&quot;... and t.viewed = false&quot;)<\/code><\/pre>\n<p>  <\/p>\n<p>\u0410\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043c\u0435\u043d\u044f\u0435\u0442 false \u043d\u0430 0. \u0410 \u0435\u0441\u043b\u0438 \u0447\u0435\u0440\u0435\u0437 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440, \u0442\u043e \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e:<\/p>\n<p>  <\/p>\n<pre><code class=\"java\">Session.createQuery(&quot;... and t.viewed = :viewed&quot;) q.setParameter(&quot;viewed&quot;, Boolean.FALSE);<\/code><\/pre>\n<p>  <\/p>\n<p><strong>LISTAGG<\/strong><br \/>  \u0425\u043e\u0440\u043e\u0448\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f, \u043a\u043e\u0433\u0434\u0430 \u043d\u0443\u0436\u043d\u043e, \u0434\u043e\u043f\u0443\u0441\u0442\u0438\u043c, \u0432\u044b\u0432\u0435\u0441\u0442\u0438 \u0432 \u043f\u043e\u043b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0442\u0435\u043a\u0441\u0442\u0430 \u0447\u0435\u0440\u0435\u0437 \u0437\u0430\u043f\u044f\u0442\u0443\u044e. \u041d\u0435\u043f\u0440\u0438\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0437\u0430\u043a\u043b\u044e\u0447\u0430\u043b\u0430\u0441\u044c \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0432 pg \u043d\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0441\u0434\u0435\u043b\u0430\u0442\u044c listagg distinct, \u0442.\u0435. \u0432\u044b\u043a\u0438\u043d\u0443\u0442\u044c \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u044e\u0449\u0438\u0435\u0441\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f, \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c \u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0435\u0440\u0435\u0437 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441.<br \/>  <strong>\u0414\u0440\u0435\u0432\u043e\u0432\u0438\u0434\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b<\/strong><br \/>  \u0414\u0430, \u0431\u044b\u043b\u0438 \u0438 \u043e\u043d\u0438. \u0412 Oracle \u2014 \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u0441\u0432\u043e\u0439, \u043d\u0438 \u043d\u0430 \u043a\u043e\u0433\u043e \u043d\u0435 \u043f\u043e\u0445\u043e\u0436\u0438\u0439 (\u043d\u043e, \u043d\u0430 \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434, \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u044b\u0439). \u0414\u0440\u0443\u0433\u0438\u0435 \u0431\u0430\u0437\u044b \u0440\u0435\u0448\u0430\u044e\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u0447\u0435\u0440\u0435\u0437 CTE (common table expression). \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u043a\u0430\u043a \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c with recursive \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0442\u043e\u0436\u0435 \u043d\u0435 \u0432\u043e\u0437\u043d\u0438\u043a\u043b\u043e.<br \/>  <strong>\u0421\u0430\u043c\u044b\u0439 \u0441\u043b\u043e\u0436\u043d\u044b\u0439 \u043a\u0435\u0439\u0441<\/strong><br \/>  \u041e\u0434\u0438\u043d \u0438\u0437 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u00ab\u0432 \u043b\u043e\u0431\u00bb \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c. \u0414\u0435\u043b\u043e \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u0432\u0435\u0440\u0441\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0437\u0430\u043f\u0438\u0441\u0435\u0439 hibernate envers. \u041c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u0445\u043e\u0440\u043e\u0448\u0438\u0439, \u043d\u043e, \u043a\u0430\u043a \u043c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0434\u043b\u044f \u0434\u0440\u0443\u0433\u0438\u0445 \u0437\u0430\u0434\u0430\u0447. \u0427\u0442\u043e\u0431\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0432\u0435\u0440\u0441\u0438\u0438 \u043d\u0430 \u043c\u043e\u043c\u0435\u043d\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0425 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u00ab\u0434\u0436\u043e\u0439\u043d\u0438\u0442\u044c\u00bb \u0432\u0441\u0435 \u0438\u0441\u0442\u043e\u0440\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u0433\u0438\u0433\u0430\u043d\u0442\u0441\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u0432\u0435\u0440\u0441\u0438\u0439 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0438 \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0431\u043b\u0438\u0436\u0430\u0439\u0448\u0443\u044e \u043a \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0439 \u0434\u0430\u0442\u0435. \u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u0447\u0435\u0440\u0435\u0437 \u043e\u043a\u043e\u043d\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0441 rank.<br \/>  \u0414\u0438\u043a\u043e \u0442\u043e\u0440\u043c\u043e\u0437\u0438\u0442, \u0434\u0430\u0436\u0435 \u043d\u0430 Oracle. \u0412\u043e\u043e\u0431\u0449\u0435, \u0435\u0441\u043b\u0438 \u043d\u0443\u0436\u043d\u0430 \u0442\u0430\u043a\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c, \u043e\u043d\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0441\u0440\u0430\u0437\u0443 \u0438 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043e-\u0434\u0440\u0443\u0433\u043e\u043c\u0443 (\u0432\u0441\u043f\u043e\u043c\u043d\u0438\u0442\u0435, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0434\u0430\u0442\u0443 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0438\u0442\u043e\u0433\u043e\u0432 \u0432 1\u0421 \u2014 \u044d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043d\u0430 \u044d\u0442\u0443 \u0436\u0435 \u0442\u0435\u043c\u0443), \u0432\u0438\u0434\u0438\u043c\u043e \u0434\u0430\u043d\u043d\u044b\u0439 \u043e\u0442\u0447\u0435\u0442 \u0440\u043e\u0434\u0438\u043b\u0441\u044f \u043d\u0435 \u0441\u0440\u0430\u0437\u0443, \u0430 \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u044d\u0432\u043e\u043b\u044e\u0446\u0438\u0438 \u043f\u0440\u043e\u0435\u043a\u0442\u0430.<br \/>  \u041a\u0430\u043a \u043b\u044e\u0431\u0438\u0442 PG. \u0412\u043c\u0435\u043d\u044f\u0435\u043c\u043e\u0439 (\u043f\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438) \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u0447\u0435\u0440\u0435\u0434\u0443 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0442\u0430\u0431\u043b\u0438\u0446, \u0437\u0430\u043f\u043e\u043b\u043d\u044f\u044f \u0438\u0445 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u044f \u00abanalyze table\u00bb.<br \/>  \u0417\u0430\u043f\u0440\u043e\u0441 \u0432 \u0438\u0442\u043e\u0433\u0435 \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u043b\u0441\u044f \u0432 \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u0438\u0434\u0430 \u00abselect * from function()\u00bb (\u0432 Oracle \u044d\u0442\u043e \u0430\u043d\u0430\u043b\u043e\u0433 pipelined \u0444\u0443\u043d\u043a\u0446\u0438\u0438).<br \/>  <strong>\u041b\u044e\u0431\u043e\u043f\u044b\u0442\u043d\u044b\u0439 \u043a\u0435\u0439\u0441<\/strong><br \/>  \u0412 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0431\u044b\u043b\u0430 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0430\u044f \u043f\u0440\u043e\u0441\u0430\u0434\u043a\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438. \u0412\u043e\u0442 \u0442\u0430\u043a \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u043e:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">With some_query as (select \u2026 from where type in (0,1)) select \u2026 from  join  some_query as  some_query1 on \u2026 and type = 0 join  some_query as  some_query2 on \u2026 and type = 1 <\/code><\/pre>\n<p>  <\/p>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0430:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">With  some_query1 as (select \u2026 from where type = 0), some_query2 as (select \u2026 from where type = 1) select \u2026 from  join  some_query1 on \u2026  join  some_query2 on \u2026 <\/code><\/pre>\n<p>  <\/p>\n<p>\u0422\u043e \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e.<br \/>  \u0414\u0430, \u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b\u0438 \u0438 \u0441 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u0438 \u0431\u0435\u0437 (\u0432\u0430\u0436\u043d\u043e \u2014 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0439\u0442\u0435 \u0442\u0443\u0442: <a href=\"https:\/\/habr.com\/ru\/post\/440576\/\">https:\/\/habr.com\/ru\/post\/440576\/<\/a> )<br \/>  <strong>\u041e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a \u0438 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438<\/strong><br \/>  \u041e\u0447\u0435\u043d\u044c \u0432\u0430\u0436\u043d\u0430\u044f \u0442\u0435\u043c\u0430 \u043e \u043d\u044e\u0430\u043d\u0441\u0430\u0445 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439 \u0432 Oracle \u0438 PG. \u041e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e (\u0438 \u043e\u0447\u0435\u043d\u044c \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e) \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0439\u0442\u0435 \u0441\u0442\u0430\u0442\u044c\u044e:<br \/>  <a href=\"https:\/\/franckpachot.medium.com\/postgresql-subtransactions-savepoints-and-exception-blocks-67e0fbd412af\">https:\/\/franckpachot.medium.com\/postgresql-subtransactions-savepoints-and-exception-blocks-67e0fbd412af<\/a><br \/>  \u041e\u0447\u0435\u043d\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e \u0438 \u043f\u043e \u0434\u0435\u043b\u0443.<\/p>\n<p>  <\/p>\n<h2 id=\"viktorina-interesnyh-zaprosov-kotorye-imeli-mesto-v-realnosti\">\u0412\u0438\u043a\u0442\u043e\u0440\u0438\u043d\u0430 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u043c\u0435\u043b\u0438 \u043c\u0435\u0441\u0442\u043e \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438<\/h2>\n<p>  <\/p>\n<p><strong>\u0414\u0432\u043e\u0439\u043d\u043e\u0439 to_date<\/strong><br \/>  \u042d\u0442\u043e \u0431\u044b\u043b\u0430 \u044f\u0432\u043d\u0430\u044f \u043e\u0448\u0438\u0431\u043a\u0430, \u043d\u043e \u0437\u043d\u0430\u0447\u0438\u043c\u043e\u0433\u043e \u0432\u043b\u0438\u044f\u043d\u0438\u044f \u043d\u0435 \u043e\u043a\u0430\u0437\u044b\u0432\u0430\u043b\u0430. \u041e\u0434\u043d\u0430\u043a\u043e \u043e\u0447\u0435\u043d\u044c \u0438\u0437\u044f\u0449\u043d\u043e. \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0432 Oracle (PG, \u043f\u043e\u043d\u044f\u0442\u043d\u043e, \u043d\u0435 \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u0442 \u0438\u0437-\u0437\u0430 \u0431\u043e\u043b\u0435\u0435 \u0441\u0442\u0440\u043e\u0433\u043e\u0439 \u0442\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u0438):<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">with dates as ( select to_date('19.02.2020', 'DD.MM.YYYY') dt from dual union all select to_date('21.02.2020', 'DD.MM.YYYY') dt from dual ) select TO_DATE(dt, 'YYYY-MM-DD HH24:MI:SS') from dates<\/code><\/pre>\n<p>  <\/p>\n<p>\u0423 \u043c\u0435\u043d\u044f \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0432\u044b\u0434\u0430\u043b \u0442\u043e\u0442 \u0436\u0435 \u0434\u0435\u043d\u044c \u0438 \u043c\u0435\u0441\u044f\u0446, \u043d\u043e \u00ab\u043d\u0443\u043b\u0435\u0432\u043e\u0439\u00bb \u0433\u043e\u0434 \u2014 0020. \u0425\u043e\u0442\u044f, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 nls.<\/p>\n<p>  <\/p>\n<p><strong>\u0417\u0430\u043f\u0440\u043e\u0441 \u0441 \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c\u043e\u043c<\/strong><\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\u041f\u043e\u0436\u0430\u043b\u0443\u0439 \u043f\u043e\u043a\u0430 \u044d\u0442\u043e\u0442 \u0437\u0430\u043f\u0440\u043e\u0441 \u0432 \u043c\u043e\u0435\u043c \u043b\u0438\u0447\u043d\u043e\u043c \u0442\u043e\u043f\u0435, \u044f \u0434\u0430\u0436\u0435 \u043d\u0430 \u0441\u043e\u0431\u0435\u0441\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f\u0445 \u0435\u0433\u043e \u0441\u0442\u0430\u043b \u0437\u0430\u0434\u0430\u0432\u0430\u0442\u044c. SELECT HR.* FROM SOME_TABLE HR      WHERE HR.ADDRESS_ID = (SELECT AD.ID FROM SOME_TABLE2 AD          WHERE AD.ID = (SELECT CH.ADDRESS_B_ID FROM SOME_TABLE_3 CH             WHERE CH.ID = 517425))      AND HR.PROCESS_DATE = (SELECT MAX(HR.PROCESS_DATE) FROM SOME_TABLE)     AND \u2026.<\/code><\/pre>\n<p>  <\/p>\n<p>\u041e\u0442\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u0432 pg \u043e\u043d \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u043b\u0441\u044f, \u0432 Oracle \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u043e \u0432\u043e\u043f\u0440\u043e\u0441 \u2014 \u0447\u0442\u043e \u0436\u0435 \u043e\u043d \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u0432\u044b\u0434\u0430\u0435\u0442? \u041f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0439\u0442\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445.<br \/>  (\u0434\u043b\u044f \u043d\u0435\u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u043e\u0442\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u0432 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f max() \u2014 \u0434\u043b\u044f \u043f\u043e\u043b\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u0430\u043b\u0438\u0430\u0441\u043e\u043c HR, \u043e\u0434\u043d\u0430\u043a\u043e \u0432 \u0441\u0435\u043a\u0446\u0438\u0438 FROM \u044d\u0442\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u0431\u0435\u0437 \u0430\u043b\u0438\u0430\u0441\u0430, \u0430 \u0430\u043b\u0438\u0430\u0441 \u2014 \u0443 \u043f\u0435\u0440\u0432\u043e\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e\u0439, \u0431\u0430\u0437\u043e\u0432\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u044b).<\/p>\n<p>  <\/p>\n<p><strong>\u041d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 ROWNUM<\/strong><br \/>  \u0412\u0441\u0442\u0440\u0435\u0442\u0438\u043b\u0441\u044f \u0442\u0430\u043a\u043e\u0439 \u0437\u0430\u043f\u0440\u043e\u0441:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select * from (                         select ... and rownum = 1                             union all                         select ... and rownum = 1                     ) ... and rownum = 1<\/code><\/pre>\n<p>  <\/p>\n<p>\u0410 \u043a\u0430\u043a \u044f \u0443\u0436\u0435 \u0433\u043e\u0432\u043e\u0440\u0438\u043b \u0432\u044b\u0448\u0435 \u2014 FETCH ONLY \u0432 \u043f\u043e\u0434\u0437\u0430\u0440\u043f\u043e\u0441\u0430\u0445 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0420\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u0430 \u0437\u0430\u0447\u0435\u043c \u0437\u0434\u0435\u0441\u044c \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0435 rownum? \u0420\u0430\u0437\u0432\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u0435\u0441\u043b\u0438 \u0438\u0445 \u0443\u0431\u0440\u0430\u0442\u044c?<br \/>  <strong>\u041e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043f\u043e \u043f\u0435\u0440\u0438\u043e\u0434\u0443<\/strong><br \/>  \u041c\u043d\u043e\u0433\u0438\u0435 \u043c\u0430\u0441\u0441\u0438\u0432\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0438\u043c\u0435\u044e\u0442 \u043c\u0435\u0441\u044f\u0447\u043d\u0443\u044e \u0434\u0438\u043d\u0430\u043c\u0438\u043a\u0443 (\u0447\u0430\u0449\u0435 \u0432\u0441\u0435\u0433\u043e \u0441\u0447\u0435\u0442\u0430, \u043d\u0430\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0438 \u0432\u0441\u0435 \u0447\u0442\u043e \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0441 \u0435\u0436\u0435\u043c\u0435\u0441\u044f\u0447\u043d\u044b\u043c\u0438 \u043f\u043b\u0430\u0442\u0435\u0436\u0430\u043c\u0438).<br \/>  \u0412\u044b\u0431\u043e\u0440 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0437\u0430 \u043c\u0435\u0441\u044f\u0446: <\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\u2026 trunc(bdf2.PERIOD, 'MM') = (SELECT ADD_MONTHS(trunc(SYSDATE, 'MM'), -1) FROM dual)<\/code><\/pre>\n<p>  <\/p>\n<p>\u041b\u0438\u0448\u043d\u0438\u0439 \u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441 \u043a dual, \u043e\u0442\u043a\u0430\u0437 \u043e\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043f\u043e \u043f\u0435\u0440\u0438\u043e\u0434\u0443. \u041c\u0435\u043d\u044f\u0435\u043c, \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u043c \u0432 \u043d\u0443\u0436\u043d\u044b\u0439 \u0432\u0438\u0434 (where PERIOD &gt;= \u2026 and &lt; &#8230;).<\/p>\n<p>  <\/p>\n<p><strong>Oracle \u0432\u0441\u0435\u043c\u043e\u0433\u0443\u0449\u0438\u0439, \u0447\u0442\u043e \u0436 \u0442\u044b \u0434\u0435\u043b\u0430\u0435\u0448\u044c \u0442\u043e?<\/strong><\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select         COUNT(max(some_field))     from ...     group by         ....<\/code><\/pre>\n<p>  <\/p>\n<p>\u0417\u0430\u043f\u0440\u043e\u0441 \u043e\u0447\u0435\u043d\u044c \u0438\u0437\u044f\u0449\u043d\u044b\u0439. \u041c\u043d\u0435 \u043e\u0434\u043d\u043e\u043c\u0443 \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u044b SQL \u0437\u0434\u0435\u0441\u044c \u043d\u0430\u0440\u0443\u0448\u0430\u044e\u0442\u0441\u044f? \u041d\u0435\u0442, \u043d\u0435 \u043e\u0434\u043d\u043e\u043c\u0443, PG \u043e\u0431\u044b\u0447\u043d\u043e \u0441\u043e \u043c\u043d\u043e\u0439 \u0441\u043e\u043b\u0438\u0434\u0430\u0440\u0435\u043d, \u0432 \u043d\u0435\u043c \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<br \/>  \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u041e\u0440\u0430\u043a\u043b \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u043b \u043f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u043f\u0440\u043e\u0441 &quot;\u0431\u0435\u0437 \u043a\u0430\u0443\u043d\u0442\u0430&quot;, \u0430 \u0441\u0432\u0435\u0440\u0445\u0443 \u0435\u0449\u0435 \u043d\u0430\u0434 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u043c &quot;\u043a\u0430\u0443\u043d\u0442&quot; \u043d\u0430\u0432\u0435\u0441\u0438\u043b. \u0418\u0437\u044f\u0449\u043d\u043e, \u043d\u043e \u043d\u0430\u0434\u043e \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u0430\u0442\u044c:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">select count(*) from (     select         max(some_field)     from ...     group by         .... ) q<\/code><\/pre>\n<p>  <\/p>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u0435\u043d.<\/p>\n<p>  <\/p>\n<h2 id=\"vmesto-zaklyucheniya\">\u0412\u043c\u0435\u0441\u0442\u043e \u0437\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f<\/h2>\n<p>  <\/p>\n<p>\u041a\u0430\u043a, \u0441\u043f\u0440\u043e\u0441\u0438\u0442\u0435 \u0432\u044b, \u0432\u0441\u0451? \u041d\u0435\u0442, \u043f\u043e\u043a\u0430 \u0434\u0430\u043b\u0435\u043a\u043e \u043d\u0435 \u0432\u0441\u0451, \u043f\u0440\u043e\u0435\u043a\u0442 \u0432 \u0441\u0430\u043c\u043e\u043c \u0440\u0430\u0437\u0433\u0430\u0440\u0435, \u0445\u043e\u0442\u044f \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0443\u0436\u0435 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0430. \u0412\u0447\u0435\u0440\u0430 \u043d\u0430\u043c \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c\u0441\u044f \u043f\u043e\u0447\u0442\u0438 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u043e \u2013 \u0432 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u043c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0435. \u041e\u0448\u0438\u0431\u043e\u043a \u043c\u043d\u043e\u0433\u043e, \u0442\u0435\u0441\u0442\u0438\u0440\u0443\u0435\u043c, \u0430\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u0435\u043c, \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c. \u0412\u0441\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u044b \u0440\u0435\u0448\u0430\u044e\u0442\u0441\u044f. \u0422\u0430\u043a\u0436\u0435 \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0440\u0430\u0431\u043e\u0442\u0430 \u043f\u043e \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u0440\u0438\u0435\u043c\u043e-\u0441\u0434\u0430\u0442\u043e\u0447\u043d\u044b\u0445 \u0438\u0441\u043f\u044b\u0442\u0430\u043d\u0438\u0439, \u043e\u043f\u044b\u0442\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u043b\u0443\u0430\u0442\u0430\u0446\u0438\u0438, \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u2013 \u0442.\u0435. \u0432\u0441\u0435\u0445 \u0442\u0435\u0445, \u0442\u0430\u043a \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u00ab\u043a\u0440\u043e\u0432\u0430\u0432\u043e\u043c\u0443 \u044d\u043d\u0442\u0435\u0440\u043f\u0440\u0430\u0439\u0437\u0443\u00bb \u0430\u0440\u0442\u0435\u0444\u0430\u043a\u0442\u043e\u0432.<br \/>  \u041e\u0431\u0435\u0449\u0430\u044e \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u044e, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u043a\u043e\u043d\u0435\u0446 \u0442\u043e \u0434\u043e\u0439\u0434\u0435\u043c \u0434\u043e \u0444\u0438\u043d\u0438\u0448\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\/company\/rostelecom\/blog\/566624\/\"> https:\/\/habr.com\/ru\/company\/rostelecom\/blog\/566624\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text-html post__text_v1\" id=\"post-content-body\">\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/bt\/ty\/bt\/bttybtihoctlceu7hdwzvecwrmc.jpeg\"><\/p>\n<p>  <\/p>\n<p>\u0412\u0441\u0435\u043c \u043f\u0440\u0438\u0432\u0435\u0442!<br \/>  \u0421\u0435\u0433\u043e\u0434\u043d\u044f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0435\u043c \u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u043e\u0432\u043e\u0439 \u0434\u043b\u044f \u043d\u0430\u0441 \u0442\u0435\u043c\u0435 \u2014 \u043f\u0440\u043e \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0441 Oracle \u043d\u0430 Postgres Pro (\u0434\u0430\u043b\u0435\u0435 \u0432 \u0442\u0435\u043a\u0441\u0442\u0435 \u0432\u0435\u0437\u0434\u0435 \u0441\u043e\u043a\u0440\u0430\u0449\u0443 \u0434\u043e PG). \u0412 \u043e\u0431\u0449\u0435\u043c \u0441\u043c\u044b\u0441\u043b\u0435 \u0442\u0435\u043c\u0430 \u043d\u0435 \u0441\u0442\u043e\u043b\u044c \u0443\u0436 \u043d\u043e\u0432\u0430 \u2014 \u043c\u043d\u043e\u0433\u0438\u0435 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u044d\u0442\u0438\u043c \u0442\u0430\u043a\u0436\u0435 \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u0443\u0436\u0435 \u043f\u0440\u043e\u0448\u043b\u0438 \u044d\u0442\u043e\u0442 \u043f\u0443\u0442\u044c. \u0422\u0430\u043a, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043d\u0430 \u0435\u0436\u0435\u0433\u043e\u0434\u043d\u043e\u0439 \u043a\u043e\u043d\u0444\u0435\u0440\u0435\u043d\u0446\u0438\u0438 pgConf \u0432\u0441\u0435\u0433\u0434\u0430 \u0435\u0441\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 \u0434\u043e\u043a\u043b\u0430\u0434\u043e\u0432 \u043f\u043e \u044d\u0442\u043e\u0439 \u0442\u0435\u043c\u0435 (<a href=\"https:\/\/pgconf.ru\/\">https:\/\/pgconf.ru\/<\/a>). \u0415\u0441\u043b\u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043e \u0444\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044f\u0445, \u0442\u043e \u043c\u044b \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0438\u043d\u0438\u0446\u0438\u0430\u0442\u0438\u0432\u0443 \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u043e (<a href=\"https:\/\/digital.gov.ru\/ru\/documents\/4548\/\">\u041f\u0440\u0438\u043a\u0430\u0437 \u041c\u0438\u043d\u0438\u0441\u0442\u0435\u0440\u0441\u0442\u0432\u0430 \u0441\u0432\u044f\u0437\u0438 \u00ab\u041e\u0431 \u0443\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043d\u0438\u0438 \u043f\u043b\u0430\u043d\u0430 \u043f\u043e \u0438\u043c\u043f\u043e\u0440\u0442\u043e\u0437\u0430\u043c\u0435\u0449\u0435\u043d\u0438\u044e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u0433\u043e \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0435\u043d\u0438\u044f\u00bb \u043e\u0442 01.02.2015 \u2116 96<\/a>). \u041f\u043e \u0444\u0430\u043a\u0442\u0443 \u2014 \u0435\u0449\u0451 \u0438 \u0434\u0435\u043d\u0435\u0433 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u043c, \u0441\u043b\u0435\u0437\u0430\u044f \u0441 &quot;\u043b\u0438\u0446\u0435\u043d\u0437\u0438\u043e\u043d\u043d\u043e\u0439 \u0438\u0433\u043b\u044b&quot;. \u041d\u0430 \u044d\u0442\u0443 \u0442\u0435\u043c\u0443 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u0441\u0442\u0430\u0442\u044c\u044e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c, \u0430 \u0432 \u044d\u0442\u043e\u0439 \u0440\u0435\u0447\u044c \u043f\u043e\u0439\u0434\u0451\u0442 \u043e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u0430. \u041a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e, \u0434\u043e\u0431\u0440\u043e \u043f\u043e\u0436\u0430\u043b\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434 \u043a\u0430\u0442.<\/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-326306","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/326306","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=326306"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/326306\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=326306"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=326306"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=326306"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}