{"id":332999,"date":"2022-05-11T15:00:37","date_gmt":"2022-05-11T15:00:37","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=332999"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=332999","title":{"rendered":"<span>PostgreSQL Antipatterns: \u043a\u043e\u0433\u0434\u0430 \u043c\u0435\u0448\u0430\u0435\u0442 \u0432\u043d\u0435\u0448\u043d\u0438\u0439 \u043a\u043b\u044e\u0447<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><a href=\"https:\/\/ru.wikipedia.org\/wiki\/%D0%92%D0%BD%D0%B5%D1%88%D0%BD%D0%B8%D0%B9_%D0%BA%D0%BB%D1%8E%D1%87\">\u0412\u043d\u0435\u0448\u043d\u0438\u0435 \u043a\u043b\u044e\u0447\u0438<\/a> (foreign keys) &#8212; \u043c\u043e\u0449\u043d\u044b\u0439 \u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044f \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 \u0431\u0430\u0437\u0435. \u041d\u043e \u043e\u043d \u0431\u044b\u0432\u0430\u0435\u0442 \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043b\u0438\u0448\u044c \u043f\u043e\u043b\u0435\u0437\u0435\u043d, \u0438 \u043c\u043e\u0436\u0435\u0442 \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u043f\u0440\u0438\u0433\u0440\u0443\u0437\u0438\u0442\u044c \u0432\u0430\u0448\u0443 \u0411\u0414.<\/p>\n<p>\u0412\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 \u043d\u0430 \u043f\u043b\u0430\u043d \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0438\u0437\u0431\u0435\u0436\u0430\u0442\u044c \u043c\u043d\u043e\u0433\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c &#8212; \u043a\u0430\u043a \u043f\u0440\u0438 \u0447\u0442\u0435\u043d\u0438\u0438 \u0438\u0437 \u0431\u0430\u0437\u044b, \u0442\u0430\u043a \u0438 \u043f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u0432 \u043d\u0435\u0435.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/getpro\/habr\/upload_files\/92f\/2ad\/059\/92f2ad05935bd488c6bd849fec7d337d.jpeg\" width=\"626\" height=\"417\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/92f\/2ad\/059\/92f2ad05935bd488c6bd849fec7d337d.jpeg\" data-blurred=\"true\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0422\u0440\u0430\u0434\u0438\u0446\u0438\u043e\u043d\u043d\u043e, \u043d\u0430\u0447\u043d\u0435\u043c \u0441 \u0441\u0430\u043c\u043e\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0438 &#8212; \u043f\u0430\u0440\u0430 \u0442\u0430\u0431\u043b\u0438\u0447\u0435\u043a, \u043e\u0434\u043d\u0430 \u043d\u0430 \u0434\u0440\u0443\u0433\u0443\u044e \u0441\u0441\u044b\u043b\u0430\u0435\u0442\u0441\u044f:<\/p>\n<pre><code class=\"sql\">CREATE TABLE tblpk(   k     integer       PRIMARY KEY );  CREATE TABLE tblfk(   k     integer       REFERENCES tblpk    -- \u044d\u043a\u0432\u0438\u0432\u0430\u043b\u0435\u043d\u0442\u043d\u043e tblpk(k), \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 k - PK         ON DELETE CASCADE -- \"\u043d\u0438\u0447\u0435\u0439\u043d\u044b\u0435\" \u0437\u0430\u043f\u0438\u0441\u0438 \u043d\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u044b , v     integer );<\/code><\/pre>\n<p>\u041d\u0430\u043f\u043e\u043b\u043d\u0438\u043c \u0438\u0445 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438:<\/p>\n<pre><code class=\"sql\">INSERT INTO tblpk(k) SELECT   generate_series(1, 1e3); -- [1..1000]  INSERT INTO tblfk(k, v) SELECT   (random() * (1e3 - 1))::integer + 1 -- random = [0..1] , (random() * 1e6)::integer FROM   generate_series(1, 1e6);<\/code><\/pre>\n<h2>\u041c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0439 SELECT<\/h2>\n<p>\u0410 \u0442\u0435\u043f\u0435\u0440\u044c \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0441\u0430\u043c\u044b\u043c \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043d\u044b\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c, \u0447\u0435\u0440\u0435\u0437 <code>JOIN<\/code>, \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0437\u0430\u043f\u0438\u0441\u0438 <code>tblpk<\/code> \u0438\u0437 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u0430 \u043d\u0430\u0439\u0442\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>tblfk.v<\/code>:<\/p>\n<pre><code class=\"sql\">SELECT   k , max(v) FROM   tblpk JOIN   tblfk     USING(k) WHERE   k &lt;= 10 GROUP BY   k;<\/code><\/pre>\n<p>\u0418&#8230; <code>Parallel Seq Scan<\/code> <strong>\u043f\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0443 \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/strong> <code>tblfk<\/code> &#8212; \u044d\u0442\u043e \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0435 \u0442\u043e, \u0447\u0435\u0433\u043e \u0431\u044b \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/857\/3f1\/799\/8573f179946278f9c4243707ed374e9f.png\" alt=\"\u0412\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439\" title=\"\u0412\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439\" width=\"1068\" height=\"409\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/857\/3f1\/799\/8573f179946278f9c4243707ed374e9f.png\"\/><figcaption>\u0412\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/figcaption><\/figure>\n<p>\u041a \u0441\u0447\u0430\u0441\u0442\u044c\u044e, \u0442\u0435\u043f\u0435\u0440\u044c, \u0432 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435 \u0442\u0435\u043c\u044b \u043f\u0440\u043e <a href=\"https:\/\/habr.com\/ru\/post\/659889\/\">\u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0438 \u043e\u0431 \u0443\u043f\u0443\u0449\u0435\u043d\u043d\u044b\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u0445<\/a>, \u043d\u0430\u0448 <a href=\"https:\/\/explain.tensor.ru\/\">\u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 explain.tensor.ru<\/a> <strong>\u043d\u0430\u0443\u0447\u0438\u043b\u0441\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u0430\u0442\u044c \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0443\u0437\u043b\u0435 \u0447\u0442\u0435\u043d\u0438\u044f<\/strong> (<code>Seq Scan<\/code>), \u043d\u043e \u0438 \u0441\u0442\u043e\u044f\u0449\u0435\u043c \u0432\u044b\u0448\u0435 \u043d\u0435\u0433\u043e <code>Hash Join<\/code>.<\/p>\n<p>\u0412 <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/3959820cbf77723f9050288ad752bc25:0:2022-05-11\">\u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435<\/a> \u043a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 3 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u044b\u0445 \u0432\u043e\u0440\u043a\u0435\u0440\u043e\u0432 &#171;\u0441\u0432\u043e\u0438&#187; 333333 \u0437\u0430\u043f\u0438\u0441\u0438 <code>tblfk<\/code> \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u043b \u0432 <code>Hash Join<\/code> \u0432 3164 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0438\u0440\u0443\u044e\u0449\u0443\u044e \u0437\u0430\u043f\u0438\u0441\u044c:<\/p>\n<pre><code>->  Hash Join (actual time=1.635..57.796 rows=3164 loops=3)     Hash Cond: (tblfk.k = tblpk.k)     Buffers: shared hit=8867     ->  Parallel Seq Scan on tblfk (actual time=1.506..24.588 rows=333333 loops=3)         Buffers: shared hit=8850<\/code><\/pre>\n<p>\u0410 \u0435\u0441\u043b\u0438 \u0443\u0441\u043b\u043e\u0432\u0438\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u0438 \u0434\u043b\u044f <code>tblfk<\/code> \u0443 \u043d\u0430\u0441 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e (<code>tblfk.k = tblpk.k<\/code>), \u0442\u043e \u043d\u0430\u043c \u043d\u0438\u0447\u0442\u043e \u043d\u0435 \u043c\u0435\u0448\u0430\u0435\u0442 \u043f\u043e\u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0439 \u0438\u043d\u0434\u0435\u043a\u0441:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/aa7\/78c\/796\/aa778c796389412ad02da7a237d97211.png\" alt=\"Hash Join + Seq Scan = index\" title=\"Hash Join + Seq Scan = index\" width=\"740\" height=\"433\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aa7\/78c\/796\/aa778c796389412ad02da7a237d97211.png\"\/><figcaption>Hash Join + Seq Scan = index<\/figcaption><\/figure>\n<p>\u041d\u0430\u043c \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441:<\/p>\n<pre><code class=\"sql\">CREATE INDEX CONCURRENTLY \"~tblfk-67ed26fd\"   ON tblfk(k);<\/code><\/pre>\n<p>\u0417\u0430\u043f\u043e\u043c\u043d\u0438\u043c \u044d\u0442\u043e, \u043d\u043e \u043f\u043e\u043a\u0430 \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u0435\u0433\u043e \u043d\u0430\u043a\u0430\u0442\u044b\u0432\u0430\u0442\u044c.<\/p>\n<p>\u0410 \u0437\u0430\u043e\u0434\u043d\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u043c, \u0447\u0442\u043e PostgreSQL <strong>\u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0434\u043b\u044f \u0432\u043d\u0435\u0448\u043d\u0438\u0445 \u043a\u043b\u044e\u0447\u0435\u0439<\/strong>.<\/p>\n<h2>UPDATE\/DELETE &#171;\u0442\u0443\u043f\u0438\u0442&#187;&#8230; \u043d\u0430 \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u0435?<\/h2>\n<p>\u0412\u043f\u043e\u043b\u043d\u0435 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u0432 \u0431\u0430\u0437\u0435 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c \u043f\u043e\u0434\u043e\u0431\u043d\u0430\u044f \u0442\u0430\u0431\u043b\u0438\u0447\u043a\u0430, \u043d\u043e \u0432\u044b\u0431\u043e\u0440\u043a\u0438 \u0432\u044b \u0438\u0437 \u043d\u0435\u0435 \u0434\u0435\u043b\u0430\u0435\u0442\u0435 \u043a\u0440\u0430\u0439\u043d\u0435 \u0440\u0435\u0434\u043a\u043e \u0438 \u0438\u0445 \u043d\u0435\u0441\u043f\u0435\u0448\u043d\u043e\u0441\u0442\u044c \u0441\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0435 \u043d\u0430 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c\u044b\u0439 \u043e\u0431\u044a\u0435\u043c &#8212; \u043a\u0430\u043a\u0438\u0435-\u043d\u0438\u0431\u0443\u0434\u044c \u043b\u043e\u0433\u0438, \u0437\u0430\u043f\u0438\u0441\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435, \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f, &#8230;<\/p>\n<p>\u041d\u043e \u0432\u043e\u0442 \u0442\u0430\u043c \u0437\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0443\u0434\u0430\u043b\u0438\u0442\u044c (\u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c, \u0435\u0441\u043b\u0438 \u0440\u0435\u0447\u044c \u0438\u0434\u0435\u0442 \u043e \u0441\u0442\u0430\u0440\u044b\u0445 \u0432\u0435\u0440\u0441\u0438\u044f\u0445 PostgreSQL) \u0437\u0430\u043f\u0438\u0441\u044c \u0438\u0437 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:<\/p>\n<pre><code class=\"sql\">DELETE FROM   tblpk WHERE   k = 1000;<\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/cc1\/923\/0c1\/cc19230c1686d269681a2615bc39d269.png\" alt=\"\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e foreign key\" title=\"\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e foreign key\" width=\"857\" height=\"264\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/cc1\/923\/0c1\/cc19230c1686d269681a2615bc39d269.png\"\/><figcaption>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e foreign key<\/figcaption><\/figure>\n<p>\u041e\u0443&#8230; \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0430 \u0441\u0440\u0430\u0437\u0443 <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/e932f01341c42d11a056b409ef5f648d:0:2022-05-11\">\u0430\u043a\u0446\u0435\u043d\u0442\u0438\u0440\u0443\u0435\u0442 \u043d\u0430\u0448\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435<\/a>, \u0447\u0442\u043e 99.9% \u0432\u0441\u0435\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0443\u0448\u043b\u043e \u0432\u043e\u0432\u0441\u0435 \u043d\u0435 \u043d\u0430 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0430 \u043d\u0430 <code>Trigger for constraint tblfk_k_fkey<\/code>. <\/p>\n<p>\u041f\u043e\u043c\u043d\u0438\u0442\u0435 <code>ON DELETE CASCADE<\/code> \u0432 \u043d\u0430\u0447\u0430\u043b\u0435? \u0412\u043e\u0442 \u044d\u0442\u043e \u043e\u043d \u0438 \u0435\u0441\u0442\u044c &#8212; \u043e\u0442\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0432\u043d\u0435\u0448\u043d\u0435\u0433\u043e \u043a\u043b\u044e\u0447\u0430 \u0447\u0435\u0440\u0435\u0437 \u0442\u0440\u0438\u0433\u0433\u0435\u0440.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0432\u043a\u043b\u044e\u0447\u0438\u043c <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/14\/auto-explain\">auto_explain<\/a> \u0438 \u043f\u0440\u0438\u0441\u0442\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0432 \u043b\u043e\u0433 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u043d\u0430 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u0435:<\/p>\n<pre><code class=\"sql\">LOAD 'auto_explain'; SET auto_explain.log_analyze = 'on'; SET auto_explain.log_buffers = 'on'; SET auto_explain.log_min_duration = 0; SET auto_explain.log_nested_statements = 'on'; SET auto_explain.log_timing = 'on'; SET auto_explain.log_triggers = 'on';  DELETE FROM   tblpk WHERE   k = 999;<\/code><\/pre>\n<pre><code>2022-05-11 15:02:44.196 MSK [17696] LOG:  duration: 264.759 ms  plan:   Query Text: DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"   Delete on tblfk  (cost=0.00..16925.00 rows=996 width=6) (actual time=264.757..264.757 rows=0 loops=1)     Buffers: shared hit=6252 dirtied=1279     ->  Seq Scan on tblfk  (cost=0.00..16925.00 rows=996 width=6) (actual time=0.181..143.802 rows=1016 loops=1)           Filter: (999 = k)           Rows Removed by Filter: 998497           Buffers: shared hit=4425 dirtied=467 2022-05-11 15:02:44.196 MSK [17696] CONTEXT:  SQL statement \"DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"\"<\/code><\/pre>\n<p>\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0432\u043e\u0442 \u043e\u043d \u0438 \u0435\u0441\u0442\u044c &#8212; <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/ce619d06cdba9e083b706efc85094e39:0:2022-05-11\">\u0432\u0438\u043d\u043e\u0432\u043d\u0438\u043a \u043d\u0430\u0448\u0438\u0445 \u0442\u043e\u0440\u043c\u043e\u0437\u043e\u0432<\/a> &#8212; &#171;<code>Seq Scan<\/code> \u043d\u0430 \u043c\u0438\u043b\u043b\u0438\u043e\u043d&#187;:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/291\/4d6\/d02\/2914d6d02d8cf8051b32b417a60215a4.png\" alt=\"\u041f\u0440\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0438 \u0447\u0438\u0442\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439\" title=\"\u041f\u0440\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0438 \u0447\u0438\u0442\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439\" width=\"1156\" height=\"197\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/291\/4d6\/d02\/2914d6d02d8cf8051b32b417a60215a4.png\"\/><figcaption>\u041f\u0440\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0438 \u0447\u0438\u0442\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/figcaption><\/figure>\n<p>\u041b\u043e\u0433\u0438\u0447\u043d\u043e, \u0447\u0442\u043e \u043a \u043d\u0435\u043c\u0443 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0442\u043e\u0433\u043e \u0436\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 &#8212; \u0442\u0430\u043a\u0438 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0436\u0435 \u0435\u0433\u043e:<\/p>\n<pre><code class=\"sql\">CREATE INDEX CONCURRENTLY \"~tblfk-67ed26fd\"   ON tblfk(k);<\/code><\/pre>\n<p>\u041d\u0443, \u043a\u0430\u043a \u0442\u0430\u043c \u043d\u0430\u0448\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0442\u0435\u043f\u0435\u0440\u044c?<\/p>\n<pre><code class=\"sql\">DELETE FROM   tblpk WHERE   k = 1;<\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/11c\/dc2\/57b\/11cdc257b8bfc9982953a64e00930974.png\" alt=\"\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c\u0443 FK\" title=\"\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c\u0443 FK\" width=\"576\" height=\"204\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/11c\/dc2\/57b\/11cdc257b8bfc9982953a64e00930974.png\"\/><figcaption>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c\u0443 FK<\/figcaption><\/figure>\n<p>\u0410 \u0432\u043e\u0442 \u0442\u0435\u043f\u0435\u0440\u044c <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/254e6869b0b1e6f3627a0459b76b919b:0:2022-05-11\">\u0441\u0442\u0430\u043b\u043e \u0432\u0441\u0435 \u043e\u0442\u043b\u0438\u0447\u043d\u043e<\/a> &#8212; <strong>7ms \u0432\u043c\u0435\u0441\u0442\u043e 95ms<\/strong>, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0438\u0437 <code>tblfk<\/code> \u0442\u0435\u043f\u0435\u0440\u044c \u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u0430\u0448\u0438\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c:<\/p>\n<pre><code>2022-05-11 15:13:16.566 MSK [17696] LOG:  duration: 3.166 ms  plan:   Query Text: DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"   Delete on tblfk  (cost=12.14..2399.04 rows=996 width=6) (actual time=3.151..3.151 rows=0 loops=1)     Buffers: shared hit=1550 dirtied=291     ->  Bitmap Heap Scan on tblfk  (cost=12.14..2399.04 rows=996 width=6) (actual time=0.149..0.760 rows=531 loops=1)           Recheck Cond: (1 = k)           Heap Blocks: exact=508           Buffers: shared hit=511           ->  Bitmap Index Scan on \"~tblfk-67ed26fd\"  (cost=0.00..11.89 rows=996 width=0) (actual time=0.092..0.092 rows=531 loops=1)                 Index Cond: (k = 1)                 Buffers: shared hit=3 2022-05-11 15:13:16.566 MSK [17696] CONTEXT:  SQL statement \"DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"\"<\/code><\/pre>\n<h2>INSERT \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0435\u0431\u044b\u0441\u0442\u0440<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c-\u0442\u043e \u0443 \u043d\u0430\u0441 \u0432\u0441\u0435 \u0445\u043e\u0440\u043e\u0448\u043e? \u0421 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c <code>SELECT<\/code> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u043d\u0430\u0448\u0438\u043c \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u0442\u0435\u043f\u0435\u0440\u044c \u0431\u044b\u0441\u0442\u0440\u043e, <code>UPDATE\/DELETE<\/code> &#8212; \u0442\u043e\u0436\u0435, \u0430 \u043a\u0430\u043a \u0442\u0430\u043c \u043f\u043e\u0436\u0438\u0432\u0430\u0435\u0442 <code>INSERT<\/code>?<\/p>\n<p>\u0412\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c \u0443\u0434\u0430\u043b\u0435\u043d\u043d\u044b\u0435 \u043d\u0430\u043c\u0438 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435:<\/p>\n<pre><code class=\"sql\">INSERT INTO tblpk VALUES(1),(998),(999),(1000);<\/code><\/pre>\n<p>\u0418 \u0434\u043e\u043a\u0438\u043d\u0435\u043c \u0435\u0449\u0435 \u0442\u044b\u0441\u044f\u0447\u0443 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0432 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e:<\/p>\n<pre><code class=\"sql\">INSERT INTO tblfk(k, v) SELECT   (random() * (1e3 - 1))::integer + 1 , (random() * 1e6)::integer FROM   generate_series(1, 1e3);<\/code><\/pre>\n<p>\u041a\u0430\u043a-\u0442\u043e \u0432\u0441\u0435 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u0441\u0442\u0430\u043b\u043e. \u0418 \u0435\u0441\u043b\u0438 \u043c\u044b \u0442\u0435\u043f\u0435\u0440\u044c \u0437\u0430\u0433\u043b\u044f\u043d\u0435\u043c \u0432 \u043b\u043e\u0433 \u0441\u0435\u0440\u0432\u0435\u0440\u0430, \u0442\u043e \u0443\u0432\u0438\u0434\u0438\u043c \u043c\u0430\u0441\u0441\u0443 \u043f\u043e\u0445\u043e\u0436\u0438\u0445 \u0437\u0430\u043f\u0438\u0441\u0435\u0439:<\/p>\n<pre><code>2022-05-11 15:23:00.005 MSK [17696] LOG:  duration: 0.296 ms  plan:   Query Text: SELECT 1 FROM ONLY \"public\".\"tblpk\" x WHERE \"k\" OPERATOR(pg_catalog.=) $1 FOR KEY SHARE OF x   LockRows  (cost=0.28..8.30 rows=1 width=10) (actual time=0.292..0.292 rows=1 loops=1)     Buffers: shared hit=5 dirtied=1     ->  Index Scan using tblpk_pkey on tblpk x  (cost=0.28..8.29 rows=1 width=10) (actual time=0.017..0.017 rows=1 loops=1)           Index Cond: (k = 361)           Buffers: shared hit=3 2022-05-11 15:23:00.005 MSK [17696] CONTEXT:  SQL statement \"SELECT 1 FROM ONLY \"public\".\"tblpk\" x WHERE \"k\" OPERATOR(pg_catalog.=) $1 FOR KEY SHARE OF x\"<\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c <strong>\u043f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u043a\u0430\u0436\u0434\u043e\u0439 \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u043f\u0438\u0441\u0438 \u0441\u0435\u0440\u0432\u0435\u0440 \u0438\u0434\u0435\u0442 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443<\/strong>, \u043d\u0430\u0445\u043e\u0434\u0438\u0442 \u0437\u0430\u043f\u0438\u0441\u044c \u0441 \u0438\u0441\u043a\u043e\u043c\u044b\u043c \u043a\u043b\u044e\u0447\u043e\u043c (\u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443, \u043a\u043e\u043d\u0435\u0447\u043d\u043e) \u0438 \u0432\u0435\u0448\u0430\u0435\u0442 \u043d\u0430 \u043d\u0435\u0435 <code>FOR KEY SHARE<\/code>-\u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0443, \u0447\u0442\u043e\u0431\u044b \u043d\u0438\u043a\u0442\u043e \u0435\u0435 \u043d\u0435 \u0443\u0441\u043f\u0435\u043b \u0441\u043c\u0435\u043d\u0438\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430 \u043d\u0430 \u044d\u0442\u043e\u0439 \u0437\u0430\u043f\u0438\u0441\u0438, \u043f\u043e\u043a\u0430 \u043c\u044b \u0442\u0443\u0442 \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435.<\/p>\n<p>\u041d\u0435\u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e, \u0447\u0442\u043e \u0432 <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/85365422ea87f45e8aa1caa3f30e6608:0:2022-05-11\">\u043f\u043b\u0430\u043d\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u0430<\/a> \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c \u0442\u043e\u0442 \u0436\u0435 \u043d\u0435\u0441\u0447\u0430\u0441\u0442\u043d\u044b\u0439 \u0442\u0440\u0438\u0433\u0433\u0435\u0440, \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u044e\u0449\u0438\u0439 foreign key, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043d\u044f\u043b 90% \u0432\u0441\u0435\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/a1e\/c86\/85b\/a1ec8685b4774407f9707cc4ba00d662.png\" alt=\"\u0412\u0441\u0442\u0430\u0432\u043a\u0430 \u0441 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u043e\u0439 \u0438 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u043e\u0439 foreign key\" title=\"\u0412\u0441\u0442\u0430\u0432\u043a\u0430 \u0441 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u043e\u0439 \u0438 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u043e\u0439 foreign key\" width=\"654\" height=\"204\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a1e\/c86\/85b\/a1ec8685b4774407f9707cc4ba00d662.png\"\/><figcaption>\u0412\u0441\u0442\u0430\u0432\u043a\u0430 \u0441 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u043e\u0439 \u0438 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u043e\u0439 foreign key<\/figcaption><\/figure>\n<p>\u041e\u0442\u0441\u044e\u0434\u0430 \u0432\u044b\u0432\u043e\u0434: \u0435\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e <strong>\u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u043c\u043d\u043e\u0433\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u043e \u0432 PostgreSQL<\/strong>, \u0442\u043e \u044d\u0442\u043e \u0432\u043f\u043e\u043b\u043d\u0435 \u0440\u0435\u0430\u043b\u044c\u043d\u043e, \u043d\u043e \u0432\u043d\u0435\u0448\u043d\u0438\u043c\u0438 \u043a\u043b\u044e\u0447\u0430\u043c\u0438 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043f\u043e\u0436\u0435\u0440\u0442\u0432\u043e\u0432\u0430\u0442\u044c.<\/p>\n<p>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u0445 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 PostgreSQL \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 <a href=\"https:\/\/habr.com\/ru\/post\/497008\/\">&#171;\u041f\u0438\u0448\u0435\u043c \u0432 PostgreSQL \u043d\u0430 \u0441\u0443\u0431\u0441\u0432\u0435\u0442\u043e\u0432\u043e\u0439: 1 host, 1 day, 1TB&#187;<\/a> \u0438\u043b\u0438 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u043a\u0435 \u043c\u043e\u0435\u0433\u043e \u0434\u043e\u043a\u043b\u0430\u0434\u0430 <a href=\"https:\/\/habr.com\/ru\/post\/487380\/\">&#171;\u041c\u0430\u0441\u0441\u043e\u0432\u0430\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 PostgreSQL&#187;<\/a>.<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \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\/665118\/\"> https:\/\/habr.com\/ru\/company\/tensor\/blog\/665118\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><a href=\"https:\/\/ru.wikipedia.org\/wiki\/%D0%92%D0%BD%D0%B5%D1%88%D0%BD%D0%B8%D0%B9_%D0%BA%D0%BB%D1%8E%D1%87\">\u0412\u043d\u0435\u0448\u043d\u0438\u0435 \u043a\u043b\u044e\u0447\u0438<\/a> (foreign keys) &#8212; \u043c\u043e\u0449\u043d\u044b\u0439 \u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044f \u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 \u0431\u0430\u0437\u0435. \u041d\u043e \u043e\u043d \u0431\u044b\u0432\u0430\u0435\u0442 \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043b\u0438\u0448\u044c \u043f\u043e\u043b\u0435\u0437\u0435\u043d, \u0438 \u043c\u043e\u0436\u0435\u0442 \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u043f\u0440\u0438\u0433\u0440\u0443\u0437\u0438\u0442\u044c \u0432\u0430\u0448\u0443 \u0411\u0414.<\/p>\n<p>\u0412\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 \u043d\u0430 \u043f\u043b\u0430\u043d \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0438\u0437\u0431\u0435\u0436\u0430\u0442\u044c \u043c\u043d\u043e\u0433\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c &#8212; \u043a\u0430\u043a \u043f\u0440\u0438 \u0447\u0442\u0435\u043d\u0438\u0438 \u0438\u0437 \u0431\u0430\u0437\u044b, \u0442\u0430\u043a \u0438 \u043f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u0432 \u043d\u0435\u0435.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0422\u0440\u0430\u0434\u0438\u0446\u0438\u043e\u043d\u043d\u043e, \u043d\u0430\u0447\u043d\u0435\u043c \u0441 \u0441\u0430\u043c\u043e\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0438 &#8212; \u043f\u0430\u0440\u0430 \u0442\u0430\u0431\u043b\u0438\u0447\u0435\u043a, \u043e\u0434\u043d\u0430 \u043d\u0430 \u0434\u0440\u0443\u0433\u0443\u044e \u0441\u0441\u044b\u043b\u0430\u0435\u0442\u0441\u044f:<\/p>\n<pre><code class=\"sql\">CREATE TABLE tblpk(   k     integer       PRIMARY KEY );  CREATE TABLE tblfk(   k     integer       REFERENCES tblpk    -- \u044d\u043a\u0432\u0438\u0432\u0430\u043b\u0435\u043d\u0442\u043d\u043e tblpk(k), \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 k - PK         ON DELETE CASCADE -- \"\u043d\u0438\u0447\u0435\u0439\u043d\u044b\u0435\" \u0437\u0430\u043f\u0438\u0441\u0438 \u043d\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u044b , v     integer );<\/code><\/pre>\n<p>\u041d\u0430\u043f\u043e\u043b\u043d\u0438\u043c \u0438\u0445 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438:<\/p>\n<pre><code class=\"sql\">INSERT INTO tblpk(k) SELECT   generate_series(1, 1e3); -- [1..1000]  INSERT INTO tblfk(k, v) SELECT   (random() * (1e3 - 1))::integer + 1 -- random = [0..1] , (random() * 1e6)::integer FROM   generate_series(1, 1e6);<\/code><\/pre>\n<h2>\u041c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0439 SELECT<\/h2>\n<p>\u0410 \u0442\u0435\u043f\u0435\u0440\u044c \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0441\u0430\u043c\u044b\u043c \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043d\u044b\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c, \u0447\u0435\u0440\u0435\u0437 <code>JOIN<\/code>, \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0437\u0430\u043f\u0438\u0441\u0438 <code>tblpk<\/code> \u0438\u0437 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u0430 \u043d\u0430\u0439\u0442\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>tblfk.v<\/code>:<\/p>\n<pre><code class=\"sql\">SELECT   k , max(v) FROM   tblpk JOIN   tblfk     USING(k) WHERE   k &lt;= 10 GROUP BY   k;<\/code><\/pre>\n<p>\u0418&#8230; <code>Parallel Seq Scan<\/code> <strong>\u043f\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0443 \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/strong> <code>tblfk<\/code> &#8212; \u044d\u0442\u043e \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0435 \u0442\u043e, \u0447\u0435\u0433\u043e \u0431\u044b \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c:<\/p>\n<figure class=\"full-width\"><figcaption>\u0412\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/figcaption><\/figure>\n<p>\u041a \u0441\u0447\u0430\u0441\u0442\u044c\u044e, \u0442\u0435\u043f\u0435\u0440\u044c, \u0432 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435 \u0442\u0435\u043c\u044b \u043f\u0440\u043e <a href=\"https:\/\/habr.com\/ru\/post\/659889\/\">\u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0438 \u043e\u0431 \u0443\u043f\u0443\u0449\u0435\u043d\u043d\u044b\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u0445<\/a>, \u043d\u0430\u0448 <a href=\"https:\/\/explain.tensor.ru\/\">\u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u0438\u0437\u0443\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 explain.tensor.ru<\/a> <strong>\u043d\u0430\u0443\u0447\u0438\u043b\u0441\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u0430\u0442\u044c \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0443\u0441\u043b\u043e\u0432\u0438\u044f \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0443\u0437\u043b\u0435 \u0447\u0442\u0435\u043d\u0438\u044f<\/strong> (<code>Seq Scan<\/code>), \u043d\u043e \u0438 \u0441\u0442\u043e\u044f\u0449\u0435\u043c \u0432\u044b\u0448\u0435 \u043d\u0435\u0433\u043e <code>Hash Join<\/code>.<\/p>\n<p>\u0412 <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/3959820cbf77723f9050288ad752bc25:0:2022-05-11\">\u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435<\/a> \u043a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 3 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u044b\u0445 \u0432\u043e\u0440\u043a\u0435\u0440\u043e\u0432 &#171;\u0441\u0432\u043e\u0438&#187; 333333 \u0437\u0430\u043f\u0438\u0441\u0438 <code>tblfk<\/code> \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u043b \u0432 <code>Hash Join<\/code> \u0432 3164 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0438\u0440\u0443\u044e\u0449\u0443\u044e \u0437\u0430\u043f\u0438\u0441\u044c:<\/p>\n<pre><code>->  Hash Join (actual time=1.635..57.796 rows=3164 loops=3)     Hash Cond: (tblfk.k = tblpk.k)     Buffers: shared hit=8867     ->  Parallel Seq Scan on tblfk (actual time=1.506..24.588 rows=333333 loops=3)         Buffers: shared hit=8850<\/code><\/pre>\n<p>\u0410 \u0435\u0441\u043b\u0438 \u0443\u0441\u043b\u043e\u0432\u0438\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u0438 \u0434\u043b\u044f <code>tblfk<\/code> \u0443 \u043d\u0430\u0441 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e (<code>tblfk.k = tblpk.k<\/code>), \u0442\u043e \u043d\u0430\u043c \u043d\u0438\u0447\u0442\u043e \u043d\u0435 \u043c\u0435\u0448\u0430\u0435\u0442 \u043f\u043e\u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0439 \u0438\u043d\u0434\u0435\u043a\u0441:<\/p>\n<figure class=\"full-width\"><figcaption>Hash Join + Seq Scan = index<\/figcaption><\/figure>\n<p>\u041d\u0430\u043c \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0438\u043d\u0434\u0435\u043a\u0441:<\/p>\n<pre><code class=\"sql\">CREATE INDEX CONCURRENTLY \"~tblfk-67ed26fd\"   ON tblfk(k);<\/code><\/pre>\n<p>\u0417\u0430\u043f\u043e\u043c\u043d\u0438\u043c \u044d\u0442\u043e, \u043d\u043e \u043f\u043e\u043a\u0430 \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u0435\u0433\u043e \u043d\u0430\u043a\u0430\u0442\u044b\u0432\u0430\u0442\u044c.<\/p>\n<p>\u0410 \u0437\u0430\u043e\u0434\u043d\u043e \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u043c, \u0447\u0442\u043e PostgreSQL <strong>\u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0434\u043b\u044f \u0432\u043d\u0435\u0448\u043d\u0438\u0445 \u043a\u043b\u044e\u0447\u0435\u0439<\/strong>.<\/p>\n<h2>UPDATE\/DELETE &#171;\u0442\u0443\u043f\u0438\u0442&#187;&#8230; \u043d\u0430 \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u0435?<\/h2>\n<p>\u0412\u043f\u043e\u043b\u043d\u0435 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u0432 \u0431\u0430\u0437\u0435 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c \u043f\u043e\u0434\u043e\u0431\u043d\u0430\u044f \u0442\u0430\u0431\u043b\u0438\u0447\u043a\u0430, \u043d\u043e \u0432\u044b\u0431\u043e\u0440\u043a\u0438 \u0432\u044b \u0438\u0437 \u043d\u0435\u0435 \u0434\u0435\u043b\u0430\u0435\u0442\u0435 \u043a\u0440\u0430\u0439\u043d\u0435 \u0440\u0435\u0434\u043a\u043e \u0438 \u0438\u0445 \u043d\u0435\u0441\u043f\u0435\u0448\u043d\u043e\u0441\u0442\u044c \u0441\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0435 \u043d\u0430 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c\u044b\u0439 \u043e\u0431\u044a\u0435\u043c &#8212; \u043a\u0430\u043a\u0438\u0435-\u043d\u0438\u0431\u0443\u0434\u044c \u043b\u043e\u0433\u0438, \u0437\u0430\u043f\u0438\u0441\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435, \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f, &#8230;<\/p>\n<p>\u041d\u043e \u0432\u043e\u0442 \u0442\u0430\u043c \u0437\u0430\u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c \u0443\u0434\u0430\u043b\u0438\u0442\u044c (\u0438\u043b\u0438 \u0434\u0430\u0436\u0435 \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c, \u0435\u0441\u043b\u0438 \u0440\u0435\u0447\u044c \u0438\u0434\u0435\u0442 \u043e \u0441\u0442\u0430\u0440\u044b\u0445 \u0432\u0435\u0440\u0441\u0438\u044f\u0445 PostgreSQL) \u0437\u0430\u043f\u0438\u0441\u044c \u0438\u0437 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:<\/p>\n<pre><code class=\"sql\">DELETE FROM   tblpk WHERE   k = 1000;<\/code><\/pre>\n<figure class=\"full-width\"><figcaption>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e foreign key<\/figcaption><\/figure>\n<p>\u041e\u0443&#8230; \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0430 \u0441\u0440\u0430\u0437\u0443 <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/e932f01341c42d11a056b409ef5f648d:0:2022-05-11\">\u0430\u043a\u0446\u0435\u043d\u0442\u0438\u0440\u0443\u0435\u0442 \u043d\u0430\u0448\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435<\/a>, \u0447\u0442\u043e 99.9% \u0432\u0441\u0435\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0443\u0448\u043b\u043e \u0432\u043e\u0432\u0441\u0435 \u043d\u0435 \u043d\u0430 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u0430, \u0430 \u043d\u0430 <code>Trigger for constraint tblfk_k_fkey<\/code>. <\/p>\n<p>\u041f\u043e\u043c\u043d\u0438\u0442\u0435 <code>ON DELETE CASCADE<\/code> \u0432 \u043d\u0430\u0447\u0430\u043b\u0435? \u0412\u043e\u0442 \u044d\u0442\u043e \u043e\u043d \u0438 \u0435\u0441\u0442\u044c &#8212; \u043e\u0442\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0432\u043d\u0435\u0448\u043d\u0435\u0433\u043e \u043a\u043b\u044e\u0447\u0430 \u0447\u0435\u0440\u0435\u0437 \u0442\u0440\u0438\u0433\u0433\u0435\u0440.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0432\u043a\u043b\u044e\u0447\u0438\u043c <a href=\"https:\/\/postgrespro.ru\/docs\/postgresql\/14\/auto-explain\">auto_explain<\/a> \u0438 \u043f\u0440\u0438\u0441\u0442\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0432 \u043b\u043e\u0433 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u043d\u0430 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u0435:<\/p>\n<pre><code class=\"sql\">LOAD 'auto_explain'; SET auto_explain.log_analyze = 'on'; SET auto_explain.log_buffers = 'on'; SET auto_explain.log_min_duration = 0; SET auto_explain.log_nested_statements = 'on'; SET auto_explain.log_timing = 'on'; SET auto_explain.log_triggers = 'on';  DELETE FROM   tblpk WHERE   k = 999;<\/code><\/pre>\n<pre><code>2022-05-11 15:02:44.196 MSK [17696] LOG:  duration: 264.759 ms  plan:   Query Text: DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"   Delete on tblfk  (cost=0.00..16925.00 rows=996 width=6) (actual time=264.757..264.757 rows=0 loops=1)     Buffers: shared hit=6252 dirtied=1279     ->  Seq Scan on tblfk  (cost=0.00..16925.00 rows=996 width=6) (actual time=0.181..143.802 rows=1016 loops=1)           Filter: (999 = k)           Rows Removed by Filter: 998497           Buffers: shared hit=4425 dirtied=467 2022-05-11 15:02:44.196 MSK [17696] CONTEXT:  SQL statement \"DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"\"<\/code><\/pre>\n<p>\u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0432\u043e\u0442 \u043e\u043d \u0438 \u0435\u0441\u0442\u044c &#8212; <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/ce619d06cdba9e083b706efc85094e39:0:2022-05-11\">\u0432\u0438\u043d\u043e\u0432\u043d\u0438\u043a \u043d\u0430\u0448\u0438\u0445 \u0442\u043e\u0440\u043c\u043e\u0437\u043e\u0432<\/a> &#8212; &#171;<code>Seq Scan<\/code> \u043d\u0430 \u043c\u0438\u043b\u043b\u0438\u043e\u043d&#187;:<\/p>\n<figure class=\"full-width\"><figcaption>\u041f\u0440\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0438 \u0447\u0438\u0442\u0430\u0435\u043c \u043c\u0438\u043b\u043b\u0438\u043e\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439<\/figcaption><\/figure>\n<p>\u041b\u043e\u0433\u0438\u0447\u043d\u043e, \u0447\u0442\u043e \u043a \u043d\u0435\u043c\u0443 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u043e\u0432\u0430\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0442\u043e\u0433\u043e \u0436\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 &#8212; \u0442\u0430\u043a\u0438 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0436\u0435 \u0435\u0433\u043e:<\/p>\n<pre><code class=\"sql\">CREATE INDEX CONCURRENTLY \"~tblfk-67ed26fd\"   ON tblfk(k);<\/code><\/pre>\n<p>\u041d\u0443, \u043a\u0430\u043a \u0442\u0430\u043c \u043d\u0430\u0448\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0442\u0435\u043f\u0435\u0440\u044c?<\/p>\n<pre><code class=\"sql\">DELETE FROM   tblpk WHERE   k = 1;<\/code><\/pre>\n<figure class=\"full-width\"><figcaption>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c\u0443 FK<\/figcaption><\/figure>\n<p>\u0410 \u0432\u043e\u0442 \u0442\u0435\u043f\u0435\u0440\u044c <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/254e6869b0b1e6f3627a0459b76b919b:0:2022-05-11\">\u0441\u0442\u0430\u043b\u043e \u0432\u0441\u0435 \u043e\u0442\u043b\u0438\u0447\u043d\u043e<\/a> &#8212; <strong>7ms \u0432\u043c\u0435\u0441\u0442\u043e 95ms<\/strong>, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0438\u0437 <code>tblfk<\/code> \u0442\u0435\u043f\u0435\u0440\u044c \u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u0430\u0448\u0438\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c:<\/p>\n<pre><code>2022-05-11 15:13:16.566 MSK [17696] LOG:  duration: 3.166 ms  plan:   Query Text: DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"   Delete on tblfk  (cost=12.14..2399.04 rows=996 width=6) (actual time=3.151..3.151 rows=0 loops=1)     Buffers: shared hit=1550 dirtied=291     ->  Bitmap Heap Scan on tblfk  (cost=12.14..2399.04 rows=996 width=6) (actual time=0.149..0.760 rows=531 loops=1)           Recheck Cond: (1 = k)           Heap Blocks: exact=508           Buffers: shared hit=511           ->  Bitmap Index Scan on \"~tblfk-67ed26fd\"  (cost=0.00..11.89 rows=996 width=0) (actual time=0.092..0.092 rows=531 loops=1)                 Index Cond: (k = 1)                 Buffers: shared hit=3 2022-05-11 15:13:16.566 MSK [17696] CONTEXT:  SQL statement \"DELETE FROM ONLY \"public\".\"tblfk\" WHERE $1 OPERATOR(pg_catalog.=) \"k\"\"<\/code><\/pre>\n<h2>INSERT \u0441\u043e\u0432\u0441\u0435\u043c \u043d\u0435\u0431\u044b\u0441\u0442\u0440<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c-\u0442\u043e \u0443 \u043d\u0430\u0441 \u0432\u0441\u0435 \u0445\u043e\u0440\u043e\u0448\u043e? \u0421 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c <code>SELECT<\/code> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u043d\u0430\u0448\u0438\u043c \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c \u0442\u0435\u043f\u0435\u0440\u044c \u0431\u044b\u0441\u0442\u0440\u043e, <code>UPDATE\/DELETE<\/code> &#8212; \u0442\u043e\u0436\u0435, \u0430 \u043a\u0430\u043a \u0442\u0430\u043c \u043f\u043e\u0436\u0438\u0432\u0430\u0435\u0442 <code>INSERT<\/code>?<\/p>\n<p>\u0412\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c \u0443\u0434\u0430\u043b\u0435\u043d\u043d\u044b\u0435 \u043d\u0430\u043c\u0438 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435:<\/p>\n<pre><code class=\"sql\">INSERT INTO tblpk VALUES(1),(998),(999),(1000);<\/code><\/pre>\n<p>\u0418 \u0434\u043e\u043a\u0438\u043d\u0435\u043c \u0435\u0449\u0435 \u0442\u044b\u0441\u044f\u0447\u0443 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0432 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e:<\/p>\n<pre><code class=\"sql\">INSERT INTO tblfk(k, v) SELECT   (random() * (1e3 - 1))::integer + 1 , (random() * 1e6)::integer FROM   generate_series(1, 1e3);<\/code><\/pre>\n<p>\u041a\u0430\u043a-\u0442\u043e \u0432\u0441\u0435 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u0441\u0442\u0430\u043b\u043e. \u0418 \u0435\u0441\u043b\u0438 \u043c\u044b \u0442\u0435\u043f\u0435\u0440\u044c \u0437\u0430\u0433\u043b\u044f\u043d\u0435\u043c \u0432 \u043b\u043e\u0433 \u0441\u0435\u0440\u0432\u0435\u0440\u0430, \u0442\u043e \u0443\u0432\u0438\u0434\u0438\u043c \u043c\u0430\u0441\u0441\u0443 \u043f\u043e\u0445\u043e\u0436\u0438\u0445 \u0437\u0430\u043f\u0438\u0441\u0435\u0439:<\/p>\n<pre><code>2022-05-11 15:23:00.005 MSK [17696] LOG:  duration: 0.296 ms  plan:   Query Text: SELECT 1 FROM ONLY \"public\".\"tblpk\" x WHERE \"k\" OPERATOR(pg_catalog.=) $1 FOR KEY SHARE OF x   LockRows  (cost=0.28..8.30 rows=1 width=10) (actual time=0.292..0.292 rows=1 loops=1)     Buffers: shared hit=5 dirtied=1     ->  Index Scan using tblpk_pkey on tblpk x  (cost=0.28..8.29 rows=1 width=10) (actual time=0.017..0.017 rows=1 loops=1)           Index Cond: (k = 361)           Buffers: shared hit=3 2022-05-11 15:23:00.005 MSK [17696] CONTEXT:  SQL statement \"SELECT 1 FROM ONLY \"public\".\"tblpk\" x WHERE \"k\" OPERATOR(pg_catalog.=) $1 FOR KEY SHARE OF x\"<\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c <strong>\u043f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u043a\u0430\u0436\u0434\u043e\u0439 \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u043f\u0438\u0441\u0438 \u0441\u0435\u0440\u0432\u0435\u0440 \u0438\u0434\u0435\u0442 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443<\/strong>, \u043d\u0430\u0445\u043e\u0434\u0438\u0442 \u0437\u0430\u043f\u0438\u0441\u044c \u0441 \u0438\u0441\u043a\u043e\u043c\u044b\u043c \u043a\u043b\u044e\u0447\u043e\u043c (\u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443, \u043a\u043e\u043d\u0435\u0447\u043d\u043e) \u0438 \u0432\u0435\u0448\u0430\u0435\u0442 \u043d\u0430 \u043d\u0435\u0435 <code>FOR KEY SHARE<\/code>-\u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0443, \u0447\u0442\u043e\u0431\u044b \u043d\u0438\u043a\u0442\u043e \u0435\u0435 \u043d\u0435 \u0443\u0441\u043f\u0435\u043b \u0441\u043c\u0435\u043d\u0438\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430 \u043d\u0430 \u044d\u0442\u043e\u0439 \u0437\u0430\u043f\u0438\u0441\u0438, \u043f\u043e\u043a\u0430 \u043c\u044b \u0442\u0443\u0442 \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435.<\/p>\n<p>\u041d\u0435\u0443\u0434\u0438\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e, \u0447\u0442\u043e \u0432 <a href=\"https:\/\/explain.tensor.ru\/archive\/explain\/85365422ea87f45e8aa1caa3f30e6608:0:2022-05-11\">\u043f\u043b\u0430\u043d\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u0430<\/a> \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c \u0442\u043e\u0442 \u0436\u0435 \u043d\u0435\u0441\u0447\u0430\u0441\u0442\u043d\u044b\u0439 \u0442\u0440\u0438\u0433\u0433\u0435\u0440, \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u044e\u0449\u0438\u0439 foreign key, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043d\u044f\u043b 90% \u0432\u0441\u0435\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438:<\/p>\n<figure class=\"full-width\"><figcaption>\u0412\u0441\u0442\u0430\u0432\u043a\u0430 \u0441 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u043e\u0439 \u0438 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u043e\u0439 foreign key<\/figcaption><\/figure>\n<p>\u041e\u0442\u0441\u044e\u0434\u0430 \u0432\u044b\u0432\u043e\u0434: \u0435\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e <strong>\u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u043c\u043d\u043e\u0433\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u043e \u0432 PostgreSQL<\/strong>, \u0442\u043e \u044d\u0442\u043e \u0432\u043f\u043e\u043b\u043d\u0435 \u0440\u0435\u0430\u043b\u044c\u043d\u043e, \u043d\u043e \u0432\u043d\u0435\u0448\u043d\u0438\u043c\u0438 \u043a\u043b\u044e\u0447\u0430\u043c\u0438 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043f\u043e\u0436\u0435\u0440\u0442\u0432\u043e\u0432\u0430\u0442\u044c.<\/p>\n<p>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043e \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u0445 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 PostgreSQL \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 <a href=\"https:\/\/habr.com\/ru\/post\/497008\/\">&#171;\u041f\u0438\u0448\u0435\u043c \u0432 PostgreSQL \u043d\u0430 \u0441\u0443\u0431\u0441\u0432\u0435\u0442\u043e\u0432\u043e\u0439: 1 host, 1 day, 1TB&#187;<\/a> \u0438\u043b\u0438 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u043a\u0435 \u043c\u043e\u0435\u0433\u043e \u0434\u043e\u043a\u043b\u0430\u0434\u0430 <a href=\"https:\/\/habr.com\/ru\/post\/487380\/\">&#171;\u041c\u0430\u0441\u0441\u043e\u0432\u0430\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 PostgreSQL&#187;<\/a>.<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \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\/665118\/\"> https:\/\/habr.com\/ru\/company\/tensor\/blog\/665118\/<\/a><br \/><\/br><\/br><\/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-332999","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/332999","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=332999"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/332999\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=332999"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=332999"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=332999"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}