{"id":315069,"date":"2020-12-17T21:00:13","date_gmt":"2020-12-17T21:00:13","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=315069"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=315069","title":{"rendered":"SQL HowTo: \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u044b\u0439 FTS-\u043f\u043e\u0438\u0441\u043a \u0441 \u0440\u0435\u043b\u0435\u0432\u0430\u043d\u0442\u043d\u043e\u0441\u0442\u044c\u044e \u043f\u043e \u0434\u0430\u0442\u0435"},"content":{"rendered":"\n<div class=\"post__text post__text-html post__text_v1\" id=\"post-content-body\">\u0412 \u043d\u0430\u0448\u0435\u043c <a href=\"https:\/\/sbis.ru\/edo\">\u0421\u0411\u0418\u0421<\/a>, \u043a\u0430\u043a \u0438 \u0432 \u043b\u044e\u0431\u043e\u0439 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u043c\u0438, \u043f\u043e \u043c\u0435\u0440\u0435 \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445 \u0443 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u0435\u0442 \u0436\u0435\u043b\u0430\u043d\u0438\u0435 \u0438\u0445 &quot;<i>\u043f\u043e\u0438\u0441\u043a\u0430\u0442\u044c<\/i>&quot;.<\/p>\n<p>  \u041d\u043e, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043b\u044e\u0434\u0438 \u2014 \u043d\u0435 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u044b, \u0442\u043e \u0438 \u0438\u0449\u0443\u0442 \u043e\u043d\u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043a\u0430\u043a &quot;<i>\u0447\u0442\u043e-\u0442\u043e \u0442\u0430\u043c \u0442\u0430\u043a\u043e\u0435 \u0431\u044b\u043b\u043e \u043e\u0442 <b>\u0418\u0432\u0430\u043d\u043e\u0432\u0430 \u0438\u043b\u0438 \u043e\u0442 \u0418\u0432\u0430\u043d\u043e\u0432\u0441\u043a\u043e\u0433\u043e<\/b>\u2026 \u043d\u0435\u0442, \u043d\u0435 \u0442\u043e, <b>\u0440\u0430\u043d\u044c\u0448\u0435, \u0435\u0449\u0435 \u0440\u0430\u043d\u044c\u0448\u0435<\/b>\u2026 \u0432\u043e\u0442 \u043e\u043d\u043e!<\/i>&quot;<\/p>\n<p>  <a href=\"https:\/\/sbis.ru\/edo\"><\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/bq\/dh\/ep\/bqdhep-eepak6ehbuueb8ozlsls.png\"><\/div>\n<p><\/a>\u0422\u043e \u0435\u0441\u0442\u044c \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0435\u0440\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u044d\u0442\u043e <b>\u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u044b\u0439 \u043f\u043e\u043b\u043d\u043e\u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439 \u043f\u043e\u0438\u0441\u043a \u0441 \u0440\u0430\u043d\u0436\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u043f\u043e \u0434\u0430\u0442\u0435<\/b>.<\/p>\n<p>  \u041d\u043e \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 \u044d\u0442\u043e \u0433\u0440\u043e\u0437\u0438\u0442 \u0436\u0443\u0442\u043a\u0438\u043c\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u043c\u0438 \u2014 \u0432\u0435\u0434\u044c <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/12\/textsearch-tables#TEXTSEARCH-TABLES-INDEX\">\u0434\u043b\u044f FTS-\u043f\u043e\u0438\u0441\u043a\u0430 \u0432 PostgreSQL<\/a> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u00ab\u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435\u00bb <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/12\/textsearch-indexes\">\u0442\u0438\u043f\u044b \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 GIN \u0438 GiST<\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043f\u0440\u0435\u0434\u0443\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u044e\u0442 \u00ab\u043f\u043e\u0434\u0441\u043e\u0432\u044b\u0432\u0430\u043d\u0438\u044f\u00bb \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u043a\u0440\u043e\u043c\u0435 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u043e\u0433\u043e \u0432\u0435\u043a\u0442\u043e\u0440\u0430.<\/p>\n<p>  \u041e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0433\u0440\u0443\u0441\u0442\u043d\u043e <b>\u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u0437\u0430\u043f\u0438\u0441\u0438 \u043f\u043e \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u044e \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u0430<\/b> (\u0442\u044b\u0441\u044f\u0447\u0438 \u0438\u0445!) \u0438 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u043b\u0438, \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442, <b>\u0438\u0434\u0442\u0438 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443 \u0434\u0430\u0442\u044b \u0438 \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432\u0430\u0442\u044c<\/b> \u0432\u0441\u0435 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u044e\u0449\u0438\u0435\u0441\u044f \u0437\u0430\u043f\u0438\u0441\u0438 \u043d\u0430 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0435 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u0430, \u043f\u043e\u043a\u0430 \u043d\u0435 \u043d\u0430\u0439\u0434\u0435\u043c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 (\u043a\u0430\u043a \u0441\u043a\u043e\u0440\u043e \u043d\u0430\u0439\u0434\u0435\u0442\u0441\u044f \u00ab\u0430\u0431\u0440\u0430\u043a\u0430\u0434\u0430\u0431\u0440\u0430\u00bb?..).<\/p>\n<p>  \u0418 \u0442\u043e, \u0438 \u0434\u0440\u0443\u0433\u043e\u0435 \u043d\u0435 \u043e\u0441\u043e\u0431\u043e \u043f\u0440\u0438\u044f\u0442\u043d\u043e \u0434\u043b\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u0430. \u0418\u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u0432\u0441\u0435 \u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u0442\u044c \u0434\u043b\u044f \u0431\u044b\u0441\u0442\u0440\u043e\u0433\u043e \u043f\u043e\u0438\u0441\u043a\u0430?<br \/>  <a name=\"habracut\"><\/a><br \/>  \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u043c \u043d\u0430\u0448\u0438 \u00ab\u0442\u0435\u043a\u0441\u0442\u044b-\u043d\u0430-\u0434\u0430\u0442\u0443\u00bb:<\/p>\n<pre><code class=\"sql\">CREATE TABLE corpus AS SELECT   id , dt , str FROM   (     SELECT       id::integer     , now()::date - (random() * 1e3)::integer dt -- \u0434\u0430\u0442\u0430 \u0433\u0434\u0435-\u0442\u043e \u0437\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 3 \u0433\u043e\u0434\u0430     , (random() * 1e2 + 1)::integer len -- \u0434\u043b\u0438\u043d\u0430 &quot;\u0442\u0435\u043a\u0441\u0442\u0430&quot; \u0434\u043e 100     FROM       generate_series(1, 1e6) id -- 1M \u0437\u0430\u043f\u0438\u0441\u0435\u0439   ) X , LATERAL(     SELECT       string_agg(         CASE           WHEN random() &lt; 1e-1 THEN ' ' -- 10% \u043d\u0430 \u043f\u0440\u043e\u0431\u0435\u043b           ELSE chr((random() * 25 + ascii('a'))::integer)         END       , '') str     FROM       generate_series(1, len)   ) Y; <\/code><\/pre>\n<p>  <\/p>\n<h2>\u041d\u0430\u0438\u0432\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 #1: gist + btree<\/h2>\n<p>  \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u043d\u0430\u043a\u0430\u0442\u0438\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441 \u0438 \u0434\u043b\u044f FTS, \u0438 \u0434\u043b\u044f \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0438 \u043f\u043e \u0434\u0430\u0442\u0435 \u2014 \u0432\u0434\u0440\u0443\u0433 \u0434\u0430 \u043f\u043e\u043c\u043e\u0433\u0443\u0442:<\/p>\n<pre><code class=\"sql\">CREATE INDEX ON corpus(dt); CREATE INDEX ON corpus USING gist(to_tsvector('simple', str)); <\/code><\/pre>\n<p>  \u0411\u0443\u0434\u0435\u043c \u0438\u0441\u043a\u0430\u0442\u044c \u0432\u0441\u0435 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u044b, \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0438\u0435 \u0441\u043b\u043e\u0432\u0430, \u043d\u0430\u0447\u0438\u043d\u0430\u044e\u0449\u0438\u0435\u0441\u044f \u043d\u0430 <code><b>'abc...'<\/b><\/code>. \u0418, \u0434\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430, \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u043c, \u0447\u0442\u043e \u0442\u0430\u043a\u0438\u0445 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e, \u0438 FTS-\u0438\u043d\u0434\u0435\u043a\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e:<\/p>\n<pre><code class=\"sql\">SELECT   * FROM   corpus WHERE   to_tsvector('simple', str) @@ to_tsquery('simple', 'abc:*'); <\/code><\/pre>\n<p>  <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/7624ed923e2deb750d6877a09ac69a8e:0:2020-12-17\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/wa\/jo\/-e\/wajo-ejjon-10tvolm9roflc7ga.png\"><\/a><\/p>\n<p>  \u041d\u0443\u2026 \u043e\u043d, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f, \u043d\u043e \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u044d\u0442\u043e <b>\u0431\u043e\u043b\u044c\u0448\u0435 8 \u0441\u0435\u043a\u0443\u043d\u0434<\/b>, \u0447\u0442\u043e \u044f\u0432\u043d\u043e \u043d\u0435 \u0442\u043e, \u0447\u0442\u043e \u043c\u044b \u0445\u043e\u0442\u0435\u043b\u0438 \u0431\u044b \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u0442\u044c \u043d\u0430 \u043f\u043e\u0438\u0441\u043a 126 \u0437\u0430\u043f\u0438\u0441\u0435\u0439.<\/p>\n<p>  \u041c\u043e\u0436\u0435\u0442, \u0435\u0441\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c <b>\u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0443 \u043f\u043e \u0434\u0430\u0442\u0435<\/b> \u0438 \u0438\u0441\u043a\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e <b>\u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 10 \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/b> \u2014 \u0441\u0442\u0430\u043d\u0435\u0442 \u043b\u0443\u0447\u0448\u0435?<\/p>\n<pre><code class=\"sql\">SELECT   * FROM   corpus WHERE   to_tsvector('simple', str) @@ to_tsquery('simple', 'abc:*') ORDER BY   dt DESC LIMIT 10;<\/code><\/pre>\n<p>  <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/ba99f9310a1841ca11e430cde07cd255:0:2020-12-17\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/pi\/lq\/te\/pilqteos5qsfz-cxakstg5im_o0.png\"><\/a><\/p>\n<p>  \u041d\u043e \u043d\u0435\u0442, \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u0432\u0435\u0440\u0445\u0443 \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0430\u0441\u044c \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430.<\/p>\n<h2>\u041d\u0430\u0438\u0432\u043d\u044b\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 #2: btree_gist<\/h2>\n<p>  \u041d\u043e \u0432\u0435\u0434\u044c \u0435\u0441\u0442\u044c \u0436\u0435 \u043e\u0442\u043b\u0438\u0447\u043d\u043e\u0435 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 <code><a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/12\/btree-gist\">btree_gist<\/a><\/code>, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u00ab\u043f\u043e\u0434\u0441\u0443\u043d\u0443\u0442\u044c\u00bb \u0441\u043a\u0430\u043b\u044f\u0440\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0432 GiST-\u0438\u043d\u0434\u0435\u043a\u0441, \u0447\u0442\u043e \u0434\u043e\u043b\u0436\u043d\u043e \u043d\u0430\u043c \u0434\u0430\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u0440\u0430\u0437\u0443 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <b>\u0438\u043d\u0434\u0435\u043a\u0441\u043d\u0443\u044e \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0443 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430 \u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u044f <code>&lt;-&gt;<\/code><\/b>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f <a href=\"https:\/\/en.wikipedia.org\/wiki\/Nearest_neighbor_search\">kNN-\u043f\u043e\u0438\u0441\u043a\u043e\u0432<\/a>:<\/p>\n<pre><code class=\"sql\">CREATE EXTENSION btree_gist; CREATE INDEX ON corpus USING gist(to_tsvector('simple', str), dt);<\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"sql\">SELECT   * FROM   corpus WHERE   to_tsvector('simple', str) @@ to_tsquery('simple', 'abc:*') ORDER BY   dt &lt;-&gt; '2100-01-01'::date DESC -- \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u043f\u043e &quot;\u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u044e&quot; \u043e\u0442 \u0434\u0430\u0442\u044b \u0434\u0430\u043b\u0435\u043a\u043e \u0432 \u0431\u0443\u0434\u0443\u0449\u0435\u043c LIMIT 10; <\/code><\/pre>\n<p>  <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/7b70960807cb971686de92ba8cfecaa2:0:2020-12-17\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/py\/6a\/yp\/py6ayp-vrnpsjh8hkmo64ga6nfk.png\"><\/a><\/p>\n<p>  \u0423\u0432\u044b, \u044d\u0442\u043e \u043d\u0435 \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043d\u0438\u043a\u0430\u043a.<\/p>\n<h2>\u0413\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u044f \u0432 \u043f\u043e\u043c\u043e\u0449\u044c!<\/h2>\n<p>  \u041d\u043e \u043e\u0442\u0447\u0430\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u0440\u0430\u043d\u043e! \u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/12\/gist-builtin-opclasses#GIST-BUILTIN-OPCLASSES-TABLE\">\u0441\u043f\u0438\u0441\u043e\u043a \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u043e\u0432 GiST<\/a> \u2014 \u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440 \u0440\u0430\u0441\u0441\u0442\u043e\u044f\u043d\u0438\u044f <code>&lt;-&gt;<\/code> \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d <b>\u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u00ab\u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u0438\u0445\u00bb<\/b> <code>circle_ops, point_ops, poly_ops<\/code>, \u0430 \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 PostgreSQL 13 \u2014 \u0438 \u0434\u043b\u044f <code>box_ops<\/code>.<\/p>\n<p>  \u0422\u0430\u043a \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u043d\u0430\u0448\u0443 \u0437\u0430\u0434\u0430\u0447\u0443 \u00ab\u0432 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u044c\u00bb \u2014 \u043d\u0430\u0448\u0438\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0438\u043c\u0441\u044f \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 <b>\u043f\u0430\u0440\u0430\u043c <code>(\u0441\u043b\u043e\u0432\u043e, \u0434\u0430\u0442\u0430)<\/code> \u043f\u0440\u0438\u0441\u0432\u043e\u0438\u043c \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b<\/b> \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0442\u043e\u0447\u0435\u043a, \u0447\u0442\u043e\u0431\u044b \u00ab\u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u044b\u0435\u00bb \u0441\u043b\u043e\u0432\u0430 \u0438 \u043d\u0435\u0434\u0430\u043b\u0435\u043a\u043e \u043e\u0442\u0441\u0442\u043e\u044f\u0449\u0438\u0435 \u0434\u0430\u0442\u044b \u043d\u0430\u0445\u043e\u0434\u0438\u043b\u0438\u0441\u044c \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0431\u043b\u0438\u0436\u0435:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/t-\/pv\/48\/t-pv48k-v_sz49d9fuxvufnj-ak.png\"><\/p>\n<h4>\u0420\u0430\u0437\u0431\u0438\u0432\u0430\u0435\u043c \u0442\u0435\u043a\u0441\u0442 \u043d\u0430 \u0441\u043b\u043e\u0432\u0430<\/h4>\n<p>  \u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u043d\u0430\u0448 \u043f\u043e\u0438\u0441\u043a \u0431\u0443\u0434\u0435\u0442 \u043d\u0435 \u0432\u043f\u043e\u043b\u043d\u0435 \u043f\u043e\u043b\u043d\u043e\u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u043c, \u0432 \u0442\u043e\u043c \u0441\u043c\u044b\u0441\u043b\u0435, \u0447\u0442\u043e \u043d\u0435\u043b\u044c\u0437\u044f \u0437\u0430\u0434\u0430\u0432\u0430\u0442\u044c \u0443\u0441\u043b\u043e\u0432\u0438\u0435 \u0434\u043b\u044f \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u043b\u043e\u0432 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e. \u041d\u043e \u0443\u0436 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u044b\u043c-\u0442\u043e \u0442\u043e\u0447\u043d\u043e \u0431\u0443\u0434\u0435\u0442!<\/p>\n<p>  \u0421\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u043c \u0432\u0441\u043f\u043e\u043c\u043e\u0433\u0430\u0442\u0435\u043b\u044c\u043d\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443-\u0441\u043b\u043e\u0432\u0430\u0440\u044c:<\/p>\n<pre><code class=\"sql\">CREATE TABLE corpus_kw AS SELECT   id , dt , kw FROM   corpus , LATERAL (     SELECT       kw     FROM       regexp_split_to_table(lower(str), E'[^\\\\-a-z\u0430-\u044f0-9]+', 'i') kw     WHERE       length(kw) &gt; 1   ) T; <\/code><\/pre>\n<p>  \u0412 \u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u043d\u0430 1M \u00ab\u0442\u0435\u043a\u0441\u0442\u043e\u0432\u00bb \u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c 4.8M \u00ab\u0441\u043b\u043e\u0432\u00bb.<\/p>\n<h4>\u0423\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u043c \u0441\u043b\u043e\u0432\u0430<\/h4>\n<p>  \u0427\u0442\u043e\u0431\u044b \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u0441\u043b\u043e\u0432\u043e \u0432 \u0435\u0433\u043e \u00ab\u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u0443\u00bb, \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u043c \u0447\u0442\u043e <b>\u044d\u0442\u043e \u0447\u0438\u0441\u043b\u043e, \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0435 \u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0441\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u0435\u043c <code>2^16<\/code><\/b> (\u0432\u0435\u0434\u044c UNICODE-\u0441\u0438\u043c\u0432\u043e\u043b\u044b \u043c\u044b \u0442\u043e\u0436\u0435 \u0445\u043e\u0442\u0438\u043c \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0430\u0442\u044c). \u0422\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u043c\u044b \u0435\u0433\u043e \u0431\u0443\u0434\u0435\u043c \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0439 47-\u0439 \u043f\u043e\u0437\u0438\u0446\u0438\u0438:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/-z\/xk\/qg\/-zxkqgbacun7t6oshjmi-buzim4.png\"><\/p>\n<p>  \u041c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u043d\u0430\u0447\u0438\u043d\u0430\u0442\u044c \u0438 \u0441 63-\u0439 \u043f\u043e\u0437\u0438\u0446\u0438\u0438, \u044d\u0442\u043e \u0434\u0430\u0441\u0442 \u043d\u0430\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0447\u0443\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435 <code>1E+308<\/code>, \u043f\u0440\u0435\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u0434\u043b\u044f <code>double precision<\/code>, \u043d\u043e \u0442\u043e\u0433\u0434\u0430 \u0432\u043e\u0437\u043d\u0438\u043a\u043d\u0435\u0442 \u043f\u0435\u0440\u0435\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043f\u0440\u0438 \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u0430.<\/p>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043d\u0430 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u043d\u043e\u0439 \u043e\u0441\u0438 \u0432\u0441\u0435 \u0441\u043b\u043e\u0432\u0430 \u043e\u043a\u0430\u0436\u0443\u0442\u0441\u044f \u0443\u043f\u043e\u0440\u044f\u0434\u043e\u0447\u0435\u043d\u044b:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/xs\/jv\/hy\/xsjvhynznb-uje8swxxbku4_2k4.png\"><\/p>\n<pre><code class=\"sql\">ALTER TABLE corpus_kw ADD COLUMN p point;  UPDATE   corpus_kw SET   p = point(     (       SELECT         sum((2 ^ 16) ^ (64 - i) * ascii(substr(kw, i, 1)))       FROM         generate_series(1, length(kw)) i     )   , extract('epoch' from dt)   );  CREATE INDEX ON corpus_kw USING gist(p); <\/code><\/pre>\n<p>  <\/p>\n<h4>\u0424\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u043c \u043f\u043e\u0438\u0441\u043a\u043e\u0432\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441<\/h4>\n<p>  <\/p>\n<pre><code class=\"sql\">WITH src AS (   SELECT     point(       ( -- \u043a\u043e\u043f\u0438\u043f\u0430\u0441\u0442\u0443 \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u043d\u0435\u0441\u0442\u0438 \u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u044e         SELECT           sum((2 ^ 16) ^ (48 - i) * ascii(substr(kw, i, 1)))         FROM           generate_series(1, length(kw)) i       )     , extract('epoch' from dt)     ) ps   FROM     (VALUES('abc', '2100-01-01'::date)) T(kw, dt) -- \u043f\u043e\u0438\u0441\u043a\u043e\u0432\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 ) SELECT   * , src.ps &lt;-&gt; kw.p d FROM   corpus_kw kw , src ORDER BY   d LIMIT 10;<\/code><\/pre>\n<p>  <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/f36aa27e61584fb1b83343dadeb1eb4c:0:2020-12-17\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/ty\/s2\/ol\/tys2olq5ocgnelvjq3eby85mq90.png\"><\/a><\/p>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u0443 \u043d\u0430\u0441 \u043d\u0430 \u0440\u0443\u043a\u0430\u0445 <code>id<\/code> \u0438\u0441\u043a\u043e\u043c\u044b\u0445 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u043e\u0432, \u0443\u0436\u0435 \u043e\u0442\u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u0432 \u043d\u0443\u0436\u043d\u043e\u043c \u043f\u043e\u0440\u044f\u0434\u043a\u0435 \u2014 \u0438 \u0437\u0430\u043d\u044f\u043b\u043e \u044d\u0442\u043e <b>\u043c\u0435\u043d\u044c\u0448\u0435 2ms, \u0432 4000 \u0440\u0430\u0437 \u0431\u044b\u0441\u0442\u0440\u0435\u0435<\/b>!<\/p>\n<h4>\u041d\u0435\u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043b\u043e\u0436\u043a\u0430 \u0434\u0435\u0433\u0442\u044f<\/h4>\n<p>  \u041e\u043f\u0435\u0440\u0430\u0442\u043e\u0440 <code>&lt;-&gt;<\/code> \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u0437\u043d\u0430\u0435\u0442 \u043f\u0440\u043e \u043d\u0430\u0448\u0435 \u0443\u043f\u043e\u0440\u044f\u0434\u043e\u0447\u0435\u043d\u0438\u0435 \u043f\u043e \u0434\u0432\u0443\u043c \u043e\u0441\u044f\u043c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0438\u0441\u043a\u043e\u043c\u044b\u0435 \u043d\u0430\u0448\u0438 \u0434\u0430\u043d\u043d\u044b\u0435 \u043d\u0430\u0445\u043e\u0434\u044f\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u0432 \u043e\u0434\u043d\u043e\u0439 \u0438\u0437 \u043f\u0440\u0430\u0432\u044b\u0445 \u0447\u0435\u0442\u0432\u0435\u0440\u0442\u0435\u0439, \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0439 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0438 \u043f\u043e \u0434\u0430\u0442\u0435:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/h4\/j-\/ar\/h4j-ars3rhxxranstopmiq2wdza.png\"><\/p>\n<p>  \u041d\u0443 \u0438 \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u043c\u044b \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u0445\u043e\u0442\u0435\u043b\u0438 \u0441\u0430\u043c\u0438 \u0442\u0435\u043a\u0441\u0442\u044b-\u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u044b, \u0430 \u043d\u0435 \u0438\u0445 \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0435 \u0441\u043b\u043e\u0432\u0430, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f \u0434\u0430\u0432\u043d\u043e \u0437\u0430\u0431\u044b\u0442\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441:<\/p>\n<pre><code class=\"sql\">CREATE UNIQUE INDEX ON corpus(id);<\/code><\/pre>\n<p>  \u0414\u043e\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441:<\/p>\n<pre><code class=\"sql\">WITH src AS (   SELECT     point(       (         SELECT           sum((2 ^ 16) ^ (48 - i) * ascii(substr(kw, i, 1)))         FROM           generate_series(1, length(kw)) i       )     , extract('epoch' from dt)     ) ps   FROM     (VALUES('abc', '2100-01-01'::date)) T(kw, dt) -- \u043f\u043e\u0438\u0441\u043a\u043e\u0432\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 ) , dc AS (   SELECT     (       SELECT         dc       FROM         corpus dc       WHERE         id = kw.id     )   FROM     corpus_kw kw   , src   WHERE     p[0] &gt;= ps[0] AND -- kw &gt;= ...     p[1] &lt;= ps[1]     -- dt DESC   ORDER BY     src.ps &lt;-&gt; kw.p   LIMIT 10 ) SELECT   (dc).* FROM   dc;<\/code><\/pre>\n<p>  <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/2c8081edcca4e430183641285dc256ce:0:2020-12-17\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/zg\/ia\/1o\/zgia1oof4flt5pv27u3shvgm7i0.png\"><\/a><\/p>\n<p>  \u041d\u0430\u043c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u0432\u043e\u0437\u043d\u0438\u043a\u0448\u0438\u0435 <code>InitPlan<\/code> \u0441 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435\u043c \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u043d\u044b\u0445 x\/y, \u043d\u043e \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043c\u044b \u0443\u043b\u043e\u0436\u0438\u043b\u0438\u0441\u044c \u0432 \u0442\u0435 \u0436\u0435 <b>2 \u043c\u0441<\/b>!<\/p>\n<h4>\u041b\u043e\u0436\u043a\u0430 \u0434\u0435\u0433\u0442\u044f #2<\/h4>\n<p>  \u041d\u0438\u0447\u0442\u043e \u043d\u0435 \u0434\u0430\u0435\u0442\u0441\u044f \u0431\u0435\u0441\u043f\u043b\u0430\u0442\u043d\u043e:<\/p>\n<pre><code class=\"sql\">SELECT relname, pg_size_pretty(pg_total_relation_size(oid)) FROM pg_class WHERE relname LIKE 'corpus%';<\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"plaintext\">corpus          | 242 MB -- \u0438\u0441\u0445\u043e\u0434\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0442\u0435\u043a\u0441\u0442\u043e\u0432 corpus_id_idx   |  21 MB -- \u044d\u0442\u043e \u0435\u0433\u043e PK corpus_kw       | 705 MB -- \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u0435 \u0441\u043b\u043e\u0432\u0430 \u0441 \u0434\u0430\u0442\u0430\u043c\u0438 corpus_kw_p_idx | 403 MB -- GiST-\u0438\u043d\u0434\u0435\u043a\u0441 <\/code><\/pre>\n<p>  242 MB \u00ab\u0442\u0435\u043a\u0441\u0442\u043e\u0432\u00bb \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u043b\u0438\u0441\u044c \u0432 1.1GB \u00ab\u043f\u043e\u0438\u0441\u043a\u043e\u0432\u043e\u0433\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u00bb.<\/p>\n<p>  \u041d\u043e \u0432\u0435\u0434\u044c \u0432 <code>corpus_kw<\/code> \u043b\u0435\u0436\u0430\u0442 \u0434\u0430\u0442\u0430 \u0438 \u0441\u0430\u043c\u043e \u0441\u043b\u043e\u0432\u043e, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u044b \u0432 \u0441\u0430\u043c\u043e\u043c-\u0442\u043e \u043f\u043e\u0438\u0441\u043a\u0435 \u0443\u0436\u0435 \u043d\u0438\u043a\u0430\u043a \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0438 \u2014 \u0442\u0430\u043a \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0438\u0445 \u0443\u0434\u0430\u043b\u0438\u043c:<\/p>\n<pre><code class=\"sql\">ALTER TABLE corpus_kw   DROP COLUMN kw , DROP COLUMN dt;  VACUUM FULL corpus_kw;<\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"plaintext\">corpus_kw       | 641 MB -- \u0442\u043e\u043b\u044c\u043a\u043e id \u0438 point <\/code><\/pre>\n<p>  \u041c\u0435\u043b\u043e\u0447\u044c \u2014 \u0430 \u043f\u0440\u0438\u044f\u0442\u043d\u043e. \u041f\u043e\u043c\u043e\u0433\u043b\u043e \u043d\u0435 \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u0441\u0438\u043b\u044c\u043d\u043e, \u043d\u043e \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 10% \u043e\u0431\u044a\u0435\u043c\u0430 \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u043e\u0442\u044b\u0433\u0440\u0430\u0442\u044c.<\/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\/tensor\/blog\/533506\/\"> https:\/\/habr.com\/ru\/company\/tensor\/blog\/533506\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text-html post__text_v1\" id=\"post-content-body\">\u0412 \u043d\u0430\u0448\u0435\u043c <a href=\"https:\/\/sbis.ru\/edo\">\u0421\u0411\u0418\u0421<\/a>, \u043a\u0430\u043a \u0438 \u0432 \u043b\u044e\u0431\u043e\u0439 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u043c\u0438, \u043f\u043e \u043c\u0435\u0440\u0435 \u043d\u0430\u043a\u043e\u043f\u043b\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445 \u0443 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u0435\u0442 \u0436\u0435\u043b\u0430\u043d\u0438\u0435 \u0438\u0445 &quot;<i>\u043f\u043e\u0438\u0441\u043a\u0430\u0442\u044c<\/i>&quot;.<\/p>\n<p>  \u041d\u043e, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043b\u044e\u0434\u0438 \u2014 \u043d\u0435 \u043a\u043e\u043c\u043f\u044c\u044e\u0442\u0435\u0440\u044b, \u0442\u043e \u0438 \u0438\u0449\u0443\u0442 \u043e\u043d\u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043a\u0430\u043a &quot;<i>\u0447\u0442\u043e-\u0442\u043e \u0442\u0430\u043c \u0442\u0430\u043a\u043e\u0435 \u0431\u044b\u043b\u043e \u043e\u0442 <b>\u0418\u0432\u0430\u043d\u043e\u0432\u0430 \u0438\u043b\u0438 \u043e\u0442 \u0418\u0432\u0430\u043d\u043e\u0432\u0441\u043a\u043e\u0433\u043e<\/b>\u2026 \u043d\u0435\u0442, \u043d\u0435 \u0442\u043e, <b>\u0440\u0430\u043d\u044c\u0448\u0435, \u0435\u0449\u0435 \u0440\u0430\u043d\u044c\u0448\u0435<\/b>\u2026 \u0432\u043e\u0442 \u043e\u043d\u043e!<\/i>&quot;<\/p>\n<p>  <a href=\"https:\/\/sbis.ru\/edo\"><\/p>\n<div style=\"text-align:center;\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/bq\/dh\/ep\/bqdhep-eepak6ehbuueb8ozlsls.png\"><\/div>\n<p><\/a>\u0422\u043e \u0435\u0441\u0442\u044c \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0435\u0440\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u044d\u0442\u043e <b>\u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043d\u044b\u0439 \u043f\u043e\u043b\u043d\u043e\u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439 \u043f\u043e\u0438\u0441\u043a \u0441 \u0440\u0430\u043d\u0436\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u043f\u043e \u0434\u0430\u0442\u0435<\/b>.<\/p>\n<p>  \u041d\u043e \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 \u044d\u0442\u043e \u0433\u0440\u043e\u0437\u0438\u0442 \u0436\u0443\u0442\u043a\u0438\u043c\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u043c\u0438 \u2014 \u0432\u0435\u0434\u044c <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/12\/textsearch-tables#TEXTSEARCH-TABLES-INDEX\">\u0434\u043b\u044f FTS-\u043f\u043e\u0438\u0441\u043a\u0430 \u0432 PostgreSQL<\/a> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u00ab\u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435\u00bb <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/12\/textsearch-indexes\">\u0442\u0438\u043f\u044b \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 GIN \u0438 GiST<\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043f\u0440\u0435\u0434\u0443\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u044e\u0442 \u00ab\u043f\u043e\u0434\u0441\u043e\u0432\u044b\u0432\u0430\u043d\u0438\u044f\u00bb \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u043a\u0440\u043e\u043c\u0435 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u043e\u0433\u043e \u0432\u0435\u043a\u0442\u043e\u0440\u0430.<\/p>\n<p>  \u041e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0433\u0440\u0443\u0441\u0442\u043d\u043e <b>\u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u0437\u0430\u043f\u0438\u0441\u0438 \u043f\u043e \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u044e \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u0430<\/b> (\u0442\u044b\u0441\u044f\u0447\u0438 \u0438\u0445!) \u0438 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438\u043b\u0438, \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442, <b>\u0438\u0434\u0442\u0438 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443 \u0434\u0430\u0442\u044b \u0438 \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432\u0430\u0442\u044c<\/b> \u0432\u0441\u0435 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u044e\u0449\u0438\u0435\u0441\u044f \u0437\u0430\u043f\u0438\u0441\u0438 \u043d\u0430 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0435 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u0430, \u043f\u043e\u043a\u0430 \u043d\u0435 \u043d\u0430\u0439\u0434\u0435\u043c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 (\u043a\u0430\u043a \u0441\u043a\u043e\u0440\u043e \u043d\u0430\u0439\u0434\u0435\u0442\u0441\u044f \u00ab\u0430\u0431\u0440\u0430\u043a\u0430\u0434\u0430\u0431\u0440\u0430\u00bb?..).<\/p>\n<p>  \u0418 \u0442\u043e, \u0438 \u0434\u0440\u0443\u0433\u043e\u0435 \u043d\u0435 \u043e\u0441\u043e\u0431\u043e \u043f\u0440\u0438\u044f\u0442\u043d\u043e \u0434\u043b\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u0430. \u0418\u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u0432\u0441\u0435 \u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u0442\u044c \u0434\u043b\u044f \u0431\u044b\u0441\u0442\u0440\u043e\u0433\u043e \u043f\u043e\u0438\u0441\u043a\u0430?  <\/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-315069","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/315069","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=315069"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/315069\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=315069"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=315069"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=315069"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}