{"id":482888,"date":"2026-06-08T21:22:44","date_gmt":"2026-06-08T21:22:44","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=482888"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=482888","title":{"rendered":"REDB: \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0438\u043b\u0438 \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0430 \u043b\u044e\u0431\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u2014 \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/4c4\/e60\/c7d\/4c4e60c7d4639080eba48e560e282b1e.webp\" alt=\"redb index\" title=\"redb index\" width=\"1024\" height=\"1024\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/4c4\/e60\/c7d\/4c4e60c7d4639080eba48e560e282b1e.webp 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/4c4\/e60\/c7d\/4c4e60c7d4639080eba48e560e282b1e.webp 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>redb index<\/figcaption><\/div>\n<\/figure>\n<h2>REDB \u0438\u0437\u043d\u0443\u0442\u0440\u0438, \u0441\u0442\u0430\u0442\u044c\u044f 1.1: \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0438\u043b\u0438 \u043f\u043e\u0447\u0435\u043c\u0443 3 \u0442\u0430\u0431\u043b\u0438\u0446 \u043d\u0430 \u043b\u044e\u0431\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u2014 \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e<\/h2>\n<hr\/>\n<p>\u0412\u00a0<a href=\"https:\/\/habr.com\/ru\/articles\/1042058\/\" rel=\"noopener noreferrer nofollow\">\u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0447\u0430\u0441\u0442\u0438 \u0446\u0438\u043a\u043b\u0430<\/a>\u00a0\u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438 13 \u0442\u0430\u0431\u043b\u0438\u0446 REDB: \u043a\u0430\u043a \u0443\u0441\u0442\u0440\u043e\u0435\u043d\u044b\u00a0<code><em>objects<\/em><\/code><em>,\u00a0<\/em><code>values<\/code>,\u00a0<code><em>structures<\/em><\/code><em>, \u043a\u0430\u043a RTTI-\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 \u0441\u0442\u0430\u0440\u043e\u0433\u043e EAV-\u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430, \u0437\u0430\u0447\u0435\u043c \u043d\u0443\u0436\u0435\u043d\u00a0<\/em><code>scheme_metadata_cache<\/code>. \u0415\u0441\u043b\u0438 \u043d\u0435 \u0447\u0438\u0442\u0430\u043b\u0438 \u2014 \u043d\u0430\u0447\u043d\u0438\u0442\u0435 \u0441 \u043d\u0435\u0451, \u0431\u0435\u0437 \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0441\u0445\u0435\u043c\u044b \u0434\u0430\u043b\u044c\u0448\u0435 \u0442\u044f\u0436\u0435\u043b\u043e.<\/p>\n<p>\u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u2014 \u0442\u043e, \u0447\u0442\u043e \u043e\u0431\u044b\u0447\u043d\u043e \u0438\u0434\u0451\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u043c:\u00a0<strong>\u00ab\u0410 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0433\u0434\u0435? \u0423 \u0432\u0430\u0441 \u0436\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432\u0441\u0435\u0445 \u043f\u043e\u043b\u0435\u0439 \u043b\u0435\u0436\u0430\u0442 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435. \u041b\u044e\u0431\u043e\u0439 WHERE \u2014 \u044d\u0442\u043e Seq Scan \u043f\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430\u043c \u0441\u0442\u0440\u043e\u043a\u00bb.<\/strong><\/p>\n<p>\u042d\u0442\u043e \u0441\u0442\u0430\u0442\u044c\u044f 1.1, \u0430 \u043d\u0435 2 \u2014 \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u043d\u0430 \u043f\u0440\u044f\u043c\u043e\u0435 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u0430 \u043f\u0440\u043e \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435.\u00a0<strong>\u0413\u043b\u0443\u0431\u043e\u043a\u043e\u0435 \u043f\u043e\u0433\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0432 C# \u2014 \u044d\u0442\u043e \u0441\u0442\u0430\u0442\u044c\u0438 3-5 \u0446\u0438\u043a\u043b\u0430<\/strong>: Code-first \u0441\u0445\u0435\u043c\u044b (<code>SyncSchemeAsync&lt;T&gt;<\/code>), CRUD (SaveAsync\/LoadAsync), LINQ-\u0442\u0440\u0430\u043d\u0441\u043b\u044f\u0442\u043e\u0440. \u0417\u0434\u0435\u0441\u044c \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0432 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u0411\u0414 \u0438 DDL.<\/p>\n<p>\u0426\u0438\u0444\u0440\u044b, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u043f\u0438\u0440\u0430\u0435\u043c\u0441\u044f, \u2014 \u0441 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0434\u0430: TSUM, \u043b\u043e\u0433\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430, \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0435 \u0433\u0440\u0443\u0437\u043e\u0432\u0438\u043a\u043e\u0432 \u0438 \u0437\u0430\u043a\u0430\u0437\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0420\u0426.<\/p>\n<blockquote>\n<p><strong>TL;DR:<\/strong>\u00a0\u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 EF-\u0441\u0445\u0435\u043c\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043b\u043e\u0434\u044f\u0442\u0441\u044f \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438. \u0412 REDB \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0437\u0430\u0434\u0438\u0437\u0430\u0439\u043d\u0435\u043d \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0432 DDL \u0438 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u043b\u044e\u0431\u0443\u044e \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0445\u0435\u043c\u0443 \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 33-\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043d\u0438 \u043e\u0434\u043d\u043e\u0439 \u043d\u043e\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432\u00a0<code>redbPostgre.sql<\/code>. \u0410\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u0434 \u0431\u0438\u0437\u043d\u0435\u0441-\u0434\u0430\u043d\u043d\u044b\u0435 \u043b\u044e\u0431\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u2014 \u0432\u0441\u0435\u0433\u043e\u00a0<strong>2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/strong>\u00a0(<code>_objects<\/code>\u00a0+\u00a0<code>_values<\/code>), \u043f\u043b\u044e\u0441\u00a0<strong>2<\/strong>\u00a0\u043f\u043e\u0434 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438 \u0438\u00a0<strong>3<\/strong>\u00a0\u043f\u043e\u0434 RTTI; \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u2014 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430, \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u043d\u0430\u044f \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432. \u041d\u0430 \u043f\u0440\u043e\u0434\u0435 TSUM \u044d\u0442\u043e \u0434\u0430\u0451\u0442\u00a0<strong>999 \u0437\u0430\u043a\u0430\u0437\u043e\u0432 \/ 991 \u043c\u0441<\/strong>\u00a0\u043d\u0430 2 \u044f\u0434\u0440\u0430\u0445 \u0431\u0435\u0437 \u0442\u044e\u043d\u0438\u043d\u0433\u0430 PG \u0438 \u0431\u0435\u0437 \u043a\u044d\u0448\u0430 \u0443\u0440\u043e\u0432\u043d\u044f \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430: \u043e\u0434\u0438\u043d SELECT \u043d\u0430 999 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u043e\u0432 (139 \u043c\u0441), bulk-save 32 \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u0447\u0435\u0440\u0435\u0437 COPY (154 \u043c\u0441), 967 \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u043e\u0442\u0441\u0435\u0447\u0435\u043d\u044b \u0434\u043e \u0411\u0414 \u0447\u0435\u0440\u0435\u0437\u00a0<code>ComputeHash()<\/code>.<\/p>\n<\/blockquote>\n<hr\/>\n<h3>\u0412\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0441\u043a\u0435\u043f\u0442\u0438\u043a\u0430<\/h3>\n<p>\u0412\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u0435\u0442 \u043f\u043e\u0441\u043b\u0435 \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u0438 \u0441\u0442\u0430\u0442\u044c\u0438 1, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a:<\/p>\n<blockquote>\n<p>\u00ab\u041e\u043a\u0435\u0439, \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u043b\u0443\u0447\u0448\u0435, \u0447\u0435\u043c \u0441\u0442\u0440\u043e\u043a\u043e\u0432\u044b\u0439 EAV. \u041d\u043e \u0443 \u0432\u0430\u0441 \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e 9.7 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430 \u0441\u0442\u0440\u043e\u043a \u0432\u00a0<code>_values<\/code>. \u041b\u044e\u0431\u043e\u0439 \u043e\u0441\u043c\u044b\u0441\u043b\u0435\u043d\u043d\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u2014\u00a0<code>WHERE Salary &gt; 80000<\/code>\u00a0\u0438\u043b\u0438\u00a0<code>WHERE OrderDate &gt;= '2026-06-01'<\/code>\u00a0\u2014 \u044d\u0442\u043e \u043f\u043e\u0438\u0441\u043a \u0438\u0433\u043e\u043b\u043a\u0438 \u0432 \u0441\u0442\u043e\u0433\u0435. \u0411\u0435\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0435 \u043f\u043e\u043b\u0435 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0445\u0435\u043c\u044b \u0432\u044b \u0431\u0443\u0434\u0435\u0442\u0435 \u0436\u0438\u0442\u044c \u0432 Seq Scan\u00bb.<\/p>\n<\/blockquote>\n<p>\u0412\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0440\u0430\u0441\u0442\u0451\u0442 \u0438\u0437 \u0430\u0441\u0441\u043e\u0446\u0438\u0430\u0446\u0438\u0438 \u0441\u043e \u0441\u0442\u0430\u0440\u044b\u043c\u0438 EAV-\u0441\u0445\u0435\u043c\u0430\u043c\u0438 \u0432\u0438\u0434\u0430\u00a0<code>attribute_name TEXT, value TEXT<\/code>\u00a0\u2014 \u0442\u0430\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e\u00a0<code>value<\/code>\u00a0\u0431\u0435\u0441\u043f\u043e\u043b\u0435\u0437\u0435\u043d, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0440\u0430\u0437\u043d\u043e\u0442\u0438\u043f\u043d\u044b\u0435, \u0442\u0440\u0435\u0431\u0443\u044e\u0442 cast \u043d\u0430 \u043b\u0435\u0442\u0443, \u0438 \u0441\u0435\u043b\u0435\u043a\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u00a0<code>attribute_name<\/code>\u00a0\u043d\u0438\u0437\u043a\u0430\u044f.<\/p>\n<p>REDB \u0443\u0441\u0442\u0440\u043e\u0435\u043d \u0438\u043d\u0430\u0447\u0435 \u043d\u0430 \u0434\u0432\u0443\u0445 \u0443\u0440\u043e\u0432\u043d\u044f\u0445. \u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0443\u0436\u0435 \u0440\u0430\u0437\u043b\u043e\u0436\u0435\u043d\u044b \u043f\u043e \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u043a\u043e\u043b\u043e\u043d\u043a\u0430\u043c (<code>_Long<\/code>,\u00a0<code><em>String<\/em><\/code><em>,\u00a0<\/em><code>Numeric<\/code>,\u00a0<code><em>DateTimeOffset<\/em><\/code><em>&#8230;) \u2014 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e cast. \u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u0443 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438\u00a0<\/em><code>values<\/code>\u00a0\u0435\u0441\u0442\u044c\u00a0<code><em>id<\/em>structure<\/code>\u00a0\u2014 bigint-\u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 \u043f\u043e\u043b\u044f \u0441\u0445\u0435\u043c\u044b. \u041d\u0430 401 \u043f\u043e\u043b\u0435 \u0432 TSUM \u044d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u00a0<code>WHERE <em>id<\/em>structure = X<\/code>\u00a0\u0441\u0440\u0430\u0437\u0443 \u043e\u0442\u0441\u0435\u043a\u0430\u0435\u0442 ~99.75% \u0441\u0442\u0440\u043e\u043a \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0435\u0449\u0451 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435.<\/p>\n<p>\u041d\u043e \u044d\u0442\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0435. \u0412\u043e\u043f\u0440\u043e\u0441 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439:\u00a0<strong>\u043a\u0430\u043a \u0438\u043c\u0435\u043d\u043d\u043e \u0437\u0430\u0448\u0438\u0442\u044b \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0447\u0442\u043e\u0431\u044b facet-\u0437\u0430\u043f\u0440\u043e\u0441 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b \u0437\u0430 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434\u044b \u043d\u0430 9.7M \u0441\u0442\u0440\u043e\u043a?<\/strong>\u00a0\u0420\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043f\u043e \u0448\u0430\u0433\u0430\u043c.<\/p>\n<hr\/>\n<h3>\u0413\u043b\u0430\u0432\u043d\u043e\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0435 \u043d\u0430\u0431\u043b\u044e\u0434\u0435\u043d\u0438\u0435: \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u044b \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432<\/h3>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e71\/7e8\/c1c\/e717e8c1ccce3cdbc0668fd2134b8b3f.png\" alt=\"\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\" title=\"\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\" width=\"2127\" height=\"259\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/e71\/7e8\/c1c\/e717e8c1ccce3cdbc0668fd2134b8b3f.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e71\/7e8\/c1c\/e717e8c1ccce3cdbc0668fd2134b8b3f.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432<\/figcaption><\/div>\n<\/figure>\n<p>\u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 EF-\u0440\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0442\u0430\u0431\u043b\u0438\u0446 \u0440\u0430\u0441\u0442\u0451\u0442 \u043b\u0438\u043d\u0435\u0439\u043d\u043e \u0441 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. \u041d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0432 \u0441\u0440\u0435\u0434\u043d\u0435\u043c 3-5 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432: PK, \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430 FK, \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u0431\u0438\u0437\u043d\u0435\u0441-\u0444\u0438\u043b\u044c\u0442\u0440\u044b. \u041f\u043e\u044d\u0442\u043e\u043c\u0443\u00a0<strong>\u043e\u0431\u0449\u0435\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0432 \u0411\u0414 \u0440\u0430\u0441\u0442\u0451\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u043f\u043b\u0438\u043a\u0430\u0442\u0438\u0432\u043d\u043e<\/strong>\u00a0\u0441 \u0440\u043e\u0441\u0442\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0430.<\/p>\n<p>\u0412\u043e\u0437\u044c\u043c\u0451\u043c TSUM \u043a\u0430\u043a \u043f\u0440\u0438\u043c\u0435\u0440. \u0412\u043e\u0442 \u0447\u0442\u043e \u043b\u0435\u0436\u0438\u0442 \u0432\u00a0<code>tsum.Domain\/Entities<\/code>:<\/p>\n<ul>\n<li>\n<p><code>TransportationRoute<\/code>\u00a0(\u043c\u0430\u0440\u0448\u0440\u0443\u0442 \u043f\u0435\u0440\u0435\u0432\u043e\u0437\u043a\u0438)<\/p>\n<\/li>\n<li>\n<p><code>TransportationPoint<\/code>\u00a0(\u0442\u043e\u0447\u043a\u0430 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u0430)<\/p>\n<\/li>\n<li>\n<p><code>Driver<\/code>,\u00a0<code>Vehicle<\/code>,\u00a0<code>ShippingPoint<\/code>,\u00a0<code>YardPlace<\/code><\/p>\n<\/li>\n<li>\n<p><code>SliceSettings<\/code>,\u00a0<code>SliceSnapshot<\/code>,\u00a0<code>TransportSnapshot<\/code>,\u00a0<code>TransportNorm<\/code><\/p>\n<\/li>\n<li>\n<p><code>SpecialRcSettings<\/code>,\u00a0<code>TonnageGroupSettings<\/code>,\u00a0<code>GarageState<\/code><\/p>\n<\/li>\n<li>\n<p><code>TsumAdUserRef<\/code>,\u00a0<code>UserFilterPreference<\/code><\/p>\n<\/li>\n<\/ul>\n<p>15 \u00ab\u043a\u043e\u0440\u043d\u0435\u0432\u044b\u0445\u00bb \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. \u041d\u043e \u044d\u0442\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430\u0447\u0430\u043b\u043e. \u0422\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u0434\u043d\u043e\u043c\u00a0<code>TransportationRoute<\/code>\u00a0\u043c\u044b \u0432\u0438\u0434\u0438\u043c \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438:\u00a0<code>Drivers<\/code>,\u00a0<code>Vehicles<\/code>,\u00a0<code>CarMarks<\/code>,\u00a0<code>ShippingPoints<\/code>,\u00a0<code>BusinessTypes<\/code>,\u00a0<code>YardPlaces<\/code>\u00a0(\u00d72 \u2014\u00a0<code>PlaceTo<\/code>\u00a0\/\u00a0<code>PlaceFrom<\/code>),\u00a0<code>LoadingZones<\/code>,\u00a0<code>TransportStatuses<\/code>,\u00a0<code>DeliveryStatuses<\/code>,\u00a0<code>TripRisks<\/code>. \u0418 \u0432 \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437 \u0434\u0440\u0443\u0433\u0438\u0445 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u2014 \u0441\u0432\u043e\u0439 \u043d\u0430\u0431\u043e\u0440 \u043b\u0443\u043a\u0430\u043f\u043e\u0432: \u0442\u0438\u043f\u044b \u043a\u0443\u0437\u043e\u0432\u0430, \u0441\u0442\u0430\u0442\u0443\u0441\u044b \u0433\u043e\u0442\u043e\u0432\u043d\u043e\u0441\u0442\u0438, \u043f\u0440\u0438\u0447\u0438\u043d\u044b \u0437\u0430\u0434\u0435\u0440\u0436\u0435\u043a, \u043a\u043b\u0430\u0441\u0441\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b \u0440\u0435\u0439\u0441\u043e\u0432.<\/p>\n<p>\u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0441\u0445\u0435\u043c\u0435 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0430\u043a\u043e\u0439 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u0430:\u00a0<code>Drivers<\/code>,\u00a0<code>Vehicles<\/code>,\u00a0<code>CarMarks<\/code>, &#8230;, \u043f\u043b\u044e\u0441 audit\/history-\u0442\u0430\u0431\u043b\u0438\u0446\u044b (<code>TransportSnapshot<\/code>,\u00a0<code>SliceSnapshot<\/code>\u00a0\u2014 \u044d\u0442\u043e \u044f\u0432\u043d\u043e snapshot-\u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438), \u043f\u043b\u044e\u0441 M2M-\u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0434\u043b\u044f \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u043e\u043d\u043d\u044b\u0445 \u0441\u0432\u044f\u0437\u0435\u0439.\u00a0<strong>\u0420\u0435\u0430\u043b\u0438\u0441\u0442\u0438\u0447\u043d\u0430\u044f \u043e\u0446\u0435\u043d\u043a\u0430 \u0434\u043b\u044f TSUM \u0432 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0440\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0435 \u2014 60-80 \u0442\u0430\u0431\u043b\u0438\u0446.<\/strong><\/p>\n<p>\u0421 60-80 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 \u0438 \u0441\u0440\u0435\u0434\u043d\u0438\u043c\u0438 3-4 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u2014\u00a0<strong>\u043c\u0435\u0436\u0434\u0443 200 \u0438 320 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432<\/strong>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c, \u043f\u0435\u0440\u0435\u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c, \u0434\u0440\u043e\u043f\u0430\u0442\u044c \u043a\u043e\u0433\u0434\u0430 \u0443\u0441\u0442\u0430\u0440\u0435\u043b\u043e. \u041a\u0430\u0436\u0434\u044b\u0439 \u0440\u0435\u043b\u0438\u0437 \u0432 EF-\u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044e \u0432\u0438\u0434\u0430\u00a0<code>AddColumn<\/code>\u00a0+\u00a0<code>CreateIndex<\/code>. \u041d\u0430 \u0432\u0442\u043e\u0440\u043e\u0439 \u0433\u043e\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 DBA \u0438\u043b\u0438 \u0441\u0442\u0430\u0440\u0448\u0438\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043e\u0431\u0445\u043e\u0434\u0438\u0442 \u0441\u0445\u0435\u043c\u0443 \u0441 \u0444\u043e\u043d\u0430\u0440\u0438\u043a\u043e\u043c \u0438 \u0443\u0434\u0430\u043b\u044f\u0435\u0442 \u0434\u0443\u0431\u043b\u0438 (\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u043a\u043e\u043f\u0438\u043b\u0438\u0441\u044c \u0438\u0437-\u0437\u0430 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0440\u0430\u0437\u043d\u044b\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043d\u0430\u043a\u0430\u0442\u0438\u043b\u0438 \u043f\u043e\u0445\u043e\u0436\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u0447\u0443\u0442\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b).<\/p>\n<p>\u0412 REDB \u044d\u0442\u043e\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043f\u043e-\u0434\u0440\u0443\u0433\u043e\u043c\u0443. \u041d\u0430 \u0442\u0435 \u0436\u0435 32 \u0441\u0445\u0435\u043c\u044b \/ 401 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u0432 TSUM \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u2014\u00a0<strong>2 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0430<\/strong>:\u00a0<code>pk__objects<\/code>\u00a0\u0438\u00a0<code>pk__values<\/code>. \u041f\u043e\u043b\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0437\u0430\u0448\u0438\u0442 \u0432\u00a0<code>redbPostgre.sql<\/code>\u00a0\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 50 \u0448\u0442\u0443\u043a\u00a0<strong>\u043d\u0430 \u0432\u0441\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443<\/strong>. \u041d\u0435 \u043d\u0430 \u043a\u043b\u0430\u0441\u0441. \u041d\u0430 \u0441\u0438\u0441\u0442\u0435\u043c\u0443.<\/p>\n<p>\u0418 \u0437\u0434\u0435\u0441\u044c \u0432\u0430\u0436\u043d\u043e \u0441\u0440\u0430\u0437\u0443 \u0441\u043d\u044f\u0442\u044c \u043e\u0434\u043d\u043e \u043d\u0435\u0434\u043e\u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435. \u0412 \u0441\u0442\u0430\u0442\u044c\u0435 1 \u044f \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0438\u043b 13 \u0442\u0430\u0431\u043b\u0438\u0446 REDB, \u0438 \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044c \u043b\u0435\u0433\u043a\u043e \u0443\u043d\u043e\u0441\u0438\u0442 \u043c\u044b\u0441\u043b\u044c \u00ab\u0437\u043d\u0430\u0447\u0438\u0442 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0432\u0441\u0435 13\u00bb. \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u043f\u043e\u0434 \u0431\u0438\u0437\u043d\u0435\u0441-\u0434\u0430\u043d\u043d\u044b\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u0432 \u0433\u043e\u0440\u044f\u0447\u0435\u043c \u043f\u0443\u0442\u0438 \u0430\u043a\u0442\u0438\u0432\u043d\u044b \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u0442\u0430\u0431\u043b\u0438\u0446. \u0420\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0430 \u0442\u0430\u043a\u0430\u044f:<\/p>\n<ul>\n<li>\n<p><strong>\u0425\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 \u2014 2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:<\/strong>\u00a0<code><em>objects<\/em><\/code><em>\u00a0(\u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a) \u0438\u00a0<\/em><code>values<\/code>\u00a0(\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0441\u0432\u043e\u0439\u0441\u0442\u0432). \u041b\u044e\u0431\u043e\u0439\u00a0<code>Query&lt;T&gt;()<\/code>, \u043b\u044e\u0431\u043e\u0439\u00a0<code>SaveAsync<\/code>, \u043b\u044e\u0431\u043e\u0439 LINQ-\u0444\u0438\u043b\u044c\u0442\u0440 \u043f\u0440\u0438\u0437\u0435\u043c\u043b\u044f\u0435\u0442\u0441\u044f \u0438\u043c\u0435\u043d\u043d\u043e \u0441\u044e\u0434\u0430.<\/p>\n<\/li>\n<li>\n<p><strong>\u0421\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438 \u2014 2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:<\/strong>\u00a0<code><em>lists<\/em><\/code><em>\u00a0\u0438\u00a0<\/em><code>list_items<\/code>. \u042d\u0442\u043e\u00a0<code>RedbListItem<\/code>-\u043f\u043e\u043b\u044f (Driver, Vehicle, ShippingPoint \u0438 \u0442.\u0434.), \u043e\u043d\u0438 \u0448\u0430\u0440\u044f\u0442\u0441\u044f \u043c\u0435\u0436\u0434\u0443 \u043a\u043b\u0430\u0441\u0441\u0430\u043c\u0438 \u0438 \u043d\u0435 \u0440\u0430\u0441\u0442\u0443\u0442 \u043e\u0442 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043d\u043e\u0432\u043e\u0439 \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438.<\/p>\n<\/li>\n<li>\n<p><strong>RTTI \/ \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 \u0441\u0445\u0435\u043c \u2014 3 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:<\/strong>\u00a0<code><em>types<\/em><\/code><em>\u00a0(\u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043d\u044b\u0435 \u0442\u0438\u043f\u044b),\u00a0<\/em><code>schemes<\/code>\u00a0(\u043a\u043b\u0430\u0441\u0441\u044b),\u00a0<code><em>structures<\/em><\/code><em>\u00a0(\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432). \u042d\u0442\u043e \u043a\u043e\u0434 \u0434\u0432\u0438\u0436\u043a\u0430 \u0447\u0438\u0442\u0430\u0435\u0442 \u0447\u0435\u0440\u0435\u0437\u00a0<\/em><code>scheme_metadata_cache<\/code>, \u0431\u0438\u0437\u043d\u0435\u0441-\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0438\u0445 \u043d\u0435 \u0442\u0440\u043e\u0433\u0430\u044e\u0442.<\/p>\n<\/li>\n<li>\n<p><strong>\u041e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u2014 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430:<\/strong>\u00a0<code><em>users<\/em><\/code><em>,\u00a0<\/em><code>roles<\/code>,\u00a0<code><em>permissions<\/em><\/code><em>,\u00a0<\/em><code>links<\/code>,\u00a0<code><em>dependencies<\/em><\/code><em>,\u00a0<\/em><code>functions<\/code>,\u00a0<code><em>scheme<\/em>metadata_cache<\/code>, soft-delete \u043d\u0430\u00a0<code>@@__deleted<\/code>. \u042d\u0442\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043d\u0435 \u0440\u0430\u0441\u0442\u0443\u0442 \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0431\u0438\u0437\u043d\u0435\u0441-\u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0438 \u0432 \u0433\u043e\u0440\u044f\u0447\u0435\u043c \u043f\u0443\u0442\u0438 \u043d\u0435 \u0443\u0447\u0430\u0441\u0442\u0432\u0443\u044e\u0442.<\/p>\n<\/li>\n<\/ul>\n<p>\u0418\u0442\u043e\u0433\u043e: \u043a\u0430\u043a\u043e\u0439 \u0431\u044b \u043a\u043b\u0430\u0441\u0441 \u043d\u0438 \u043f\u0438\u0441\u0430\u043b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0432\u00a0<code>tsum.Domain<\/code>, \u0435\u0433\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u0441\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0432\u00a0<strong>2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/strong>\u00a0(<code>_objects<\/code>\u00a0+\u00a0<code>_values<\/code>); \u0441\u0441\u044b\u043b\u043e\u0447\u043d\u044b\u0435 \u043f\u043e\u043b\u044f \u0431\u044c\u044e\u0442 \u0432\u00a0<strong>2<\/strong>\u00a0\u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u044b\u0435; \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 \u0441\u0445\u0435\u043c\u044b \u2014 \u0432\u00a0<strong>3<\/strong>\u00a0RTTI-\u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u0428\u0435\u0441\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u043d\u0430 5 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0438 \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u043d\u0430 500. \u042d\u0442\u043e \u0438 \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442 \u00ab\u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u00bb \u2014 \u0440\u0435\u0447\u044c \u043d\u0435 \u043f\u0440\u043e \u00ab\u0432\u0441\u0435 13 \u0442\u0430\u0431\u043b\u0438\u0446 \u043d\u0430 \u0441\u0445\u0435\u043c\u0443\u00bb, \u0430 \u043f\u0440\u043e \u0442\u043e, \u0447\u0442\u043e\u00a0<strong>\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0442\u0430\u0431\u043b\u0438\u0446 \u0434\u043b\u044f \u0431\u0438\u0437\u043d\u0435\u0441-\u0434\u0430\u043d\u043d\u044b\u0445 = 2, \u0438 \u043e\u043d \u043d\u0435 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f<\/strong>.<\/p>\n<p>\u041a\u043e\u0433\u0434\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u0432\u00a0<code>tsum.Domain<\/code>\u00a033-\u0439 \u043a\u043b\u0430\u0441\u0441 \u2014 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440,\u00a0<code>WarehouseSlot<\/code>\u00a0\u2014 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u0432 \u0411\u0414 \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f:<\/p>\n<ul>\n<li>\n<p>\u043e\u0434\u043d\u0430 \u0441\u0442\u0440\u043e\u043a\u0430 \u0432\u00a0<code>_schemes<\/code>,<\/p>\n<\/li>\n<li>\n<p>N \u0441\u0442\u0440\u043e\u043a \u0432\u00a0<code>_structures<\/code>\u00a0(\u043f\u043e \u043e\u0434\u043d\u043e\u0439 \u043d\u0430 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e),<\/p>\n<\/li>\n<li>\n<p>\u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0439 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432. \u0421\u043e\u0432\u0441\u0435\u043c.<\/p>\n<\/li>\n<\/ul>\n<p>\u041f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0432\u0435\u0441\u044c \u0441\u043f\u0435\u043a\u0442\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u043a \u043d\u043e\u0432\u043e\u043c\u0443 \u043a\u043b\u0430\u0441\u0441\u0443 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0442\u0435\u043c \u0436\u0435 \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430\u00a0<code><em>objects<\/em><\/code><em>\u00a0\u0438\u00a0<\/em><code>values<\/code>, \u0447\u0442\u043e \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u043b \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0435 32. \u041f\u043e\u0438\u0441\u043a \u043f\u043e \u043f\u043e\u043b\u044e\u00a0<code><em>id<\/em>scheme = ID(WarehouseSlot)<\/code>\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u00a0<code>IX__objects__schemes<\/code>. \u041f\u043e\u0438\u0441\u043a \u043f\u043e \u0434\u0430\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u2014\u00a0<code>IX__objects__scheme_date_create<\/code>. \u041f\u043e\u0438\u0441\u043a \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u043f\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044e \u043a\u0430\u043a\u043e\u0433\u043e-\u0442\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u2014\u00a0<code>IX__values__structure_object_lookup<\/code>. \u0414\u0435\u0440\u0435\u0432\u043e \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c-\u0440\u0435\u0431\u0451\u043d\u043e\u043a \u2014\u00a0<code>IX__objects__scheme_parent<\/code>.<\/p>\n<p>\u042d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0435 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u043e, \u0440\u0430\u0434\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0441\u0442\u0430\u0442\u044c\u044f.\u00a0<strong>\u0418\u043d\u0434\u0435\u043a\u0441\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u043b\u0430\u043d \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0434\u0438\u0437\u0430\u0439\u043d\u0430 \u0434\u0432\u0438\u0436\u043a\u0430<\/strong>, \u0430 \u043d\u0435 \u0440\u0430\u0437\u043c\u0430\u0437\u0430\u043d \u043f\u043e \u0440\u0435\u043b\u0438\u0437\u0430\u043c \u0431\u0438\u0437\u043d\u0435\u0441-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f. \u0421\u043a\u0435\u043f\u0442\u0438\u043a \u0432\u043e\u0437\u0440\u0430\u0437\u0438\u0442: \u00ab\u041d\u043e \u044d\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430\u00a0<code>_values<\/code>\u00a0\u0431\u0443\u0434\u0443\u0442 \u0445\u0443\u0436\u0435, \u0447\u0435\u043c \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0435 \u043f\u043e\u043b\u0435 \u0432 EF-\u0441\u0445\u0435\u043c\u0435\u00bb. \u041d\u0435 \u0431\u0443\u0434\u0443\u0442 \u2014 \u0438 \u043d\u0438\u0436\u0435 \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c, \u043f\u043e\u0447\u0435\u043c\u0443.<\/p>\n<p>\u0412 MSSQL \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0451 \u0442\u0430\u043a \u0436\u0435. \u042d\u0442\u043e \u0432\u0430\u0436\u043d\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c \u0432\u0441\u043b\u0443\u0445: \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440 \u043d\u0435 \u043f\u0440\u043e \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0443 Postgres. \u0412\u00a0<code>redb.MSSql\/sql\/redbMSSQL.sql<\/code>\u00a0\u043b\u0435\u0436\u0438\u0442 \u0437\u0435\u0440\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432, \u0441 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u043e\u0442\u043b\u0438\u0447\u0438\u044f\u043c\u0438 (\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u043c \u0440\u0430\u0437\u0434\u0435\u043b\u0435). \u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0439 \u043f\u0440\u0438\u0451\u043c \u2014 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0441\u0445\u0435\u043c\u0435, \u0430 \u043d\u0435 \u043d\u0430 \u0431\u0438\u0437\u043d\u0435\u0441-\u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445 \u2014 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043c\u0435\u0436\u0434\u0443 \u0434\u0432\u0438\u0436\u043a\u0430\u043c\u0438 \u0431\u0435\u0437 \u043f\u043e\u0442\u0435\u0440\u044c.<\/p>\n<hr\/>\n<h3>\u041a\u0430\u0440\u0442\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432\u00a0redbPostgre.sql<\/h3>\n<p>\u0415\u0441\u043b\u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u044c DDL \u0438 \u0447\u0438\u0442\u0430\u0442\u044c \u0441\u0432\u0435\u0440\u0445\u0443 \u0432\u043d\u0438\u0437 \u2014 \u0443\u0432\u0438\u0434\u0438\u0442\u0435 ~50 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0432\u043f\u0435\u0440\u0435\u043c\u0435\u0448\u043a\u0443. \u0427\u0442\u043e\u0431\u044b \u0438\u0445 \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c, \u0443\u0434\u043e\u0431\u043d\u0435\u0435 \u0441\u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u00a0<strong>\u043f\u043e \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u044e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f<\/strong>, \u0430 \u043d\u0435 \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0435. \u0427\u0442\u043e \u0438 \u0441\u0434\u0435\u043b\u0430\u0435\u043c.<\/p>\n<h4>1. \u0423\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438 \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u044c \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 (_values)<\/h4>\n<p>\u0422\u0440\u0438 partial-unique \u0438\u043d\u0434\u0435\u043a\u0441\u0430, \u043a\u0430\u0436\u0434\u044b\u0439 \u043f\u043e\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0441\u0432\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439:<\/p>\n<pre><code class=\"sql\">-- \u0421\u043a\u0430\u043b\u044f\u0440\u043d\u044b\u0435 \u043f\u043e\u043b\u044f: \u043e\u0434\u0438\u043d \u043e\u0431\u044a\u0435\u043a\u0442 \u2014 \u043e\u0434\u043d\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u044fCREATE UNIQUE INDEX UIX__values__structure_objectON _values (_id_structure, _id_object)WHERE _array_index IS NULL AND _array_parent_id IS NULL;-- \u041c\u0430\u0440\u043a\u0435\u0440 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430\/\u043c\u0430\u0441\u0441\u0438\u0432\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044fCREATE UNIQUE INDEX UIX__values__structure_object_parentON _values (_id_structure, _id_object, _array_parent_id)WHERE _array_index IS NULL AND _array_parent_id IS NOT NULL;-- \u042d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438 \u043f\u043e \u043f\u043e\u0437\u0438\u0446\u0438\u0438\/\u043a\u043b\u044e\u0447\u0443CREATE UNIQUE INDEX UIX__values__structure_object_array_indexON _values (_id_structure, _id_object, _array_parent_id, _array_index)WHERE _array_index IS NOT NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0417\u0430\u0447\u0435\u043c \u0442\u0440\u0438, \u0430 \u043d\u0435 \u043e\u0434\u0438\u043d. \u041a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 \u044d\u0442\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u0432\u00a0<code>_values<\/code>\u00a0\u0438\u043c\u0435\u0435\u0442 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043f\u043e \u0440\u0430\u0437\u043d\u043e\u043c\u0443 \u043d\u0430\u0431\u043e\u0440\u0443 \u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u0421\u043a\u0430\u043b\u044f\u0440 \u2014 \u043f\u043e\u00a0<code>(structure, object)<\/code>. \u041c\u0430\u0440\u043a\u0435\u0440 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f\u00a0<code>parent<\/code>. \u042d\u043b\u0435\u043c\u0435\u043d\u0442 \u043c\u0430\u0441\u0441\u0438\u0432\u0430\/\u0441\u043b\u043e\u0432\u0430\u0440\u044f \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f\u00a0<code>index<\/code>. \u041e\u0434\u0438\u043d \u043e\u0431\u0449\u0438\u0439 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u0435\u043d (NULL-\u044b \u043b\u043e\u043c\u0430\u043b\u0438 \u0431\u044b \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0443), \u0430 \u0442\u0440\u0438 partial \u2014 \u0442\u043e\u0447\u043d\u043e \u043b\u043e\u0436\u0430\u0442\u0441\u044f \u043d\u0430 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u043c\u043e\u0434\u0435\u043b\u044c.<\/p>\n<p>\u0411\u043e\u043d\u0443\u0441-\u044d\u0444\u0444\u0435\u043a\u0442: \u0434\u0435\u0440\u0435\u0432\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043c\u0435\u043d\u044c\u0448\u0435, \u0447\u0435\u043c \u0443 \u043e\u0434\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u2014 \u043a\u0430\u0436\u0434\u044b\u0439 partial \u0445\u0440\u0430\u043d\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u0434\u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0440\u043e\u043a. \u041d\u0430 9.7M \u0441\u0442\u0440\u043e\u043a \u044d\u0442\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043f\u0440\u043e\u0446\u0435\u043d\u0442\u043e\u0432 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u0438 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446.<\/p>\n<h4>2. Facet search \u2014 \u0441\u0430\u043c\u043e\u0435 \u0433\u043e\u0440\u044f\u0447\u0435\u0435 \u043c\u0435\u0441\u0442\u043e<\/h4>\n<p>Facet-\u0437\u0430\u043f\u0440\u043e\u0441 REDB \u2014 \u044d\u0442\u043e \u00ab\u043d\u0430\u0439\u0434\u0438 \u043e\u0431\u044a\u0435\u043a\u0442\u044b, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u043e\u043b\u0435 X \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 Y\u00bb. \u0412 \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u0445 SQL:<\/p>\n<pre><code class=\"sql\">SELECT v._id_object FROM _values vWHERE v._id_structure = @structure_id  AND v._Long &gt; 80000<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u042d\u0442\u043e\u0442 \u0448\u0430\u0431\u043b\u043e\u043d \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0441\u0442\u0430\u0432\u043d\u044b\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c:<\/p>\n<pre><code class=\"sql\">CREATE INDEX IX__values__structure_object_lookupON _values (_id_structure, _id_object,            _Long, _DateTimeOffset, _Boolean, _Double, _Guid, _Numeric, _ListItem, _Object);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412\u0441\u0435 \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 (\u043a\u0440\u043e\u043c\u0435\u00a0<code>_String<\/code>\u00a0\u2014 \u043f\u0440\u043e \u043d\u0435\u0451 \u043d\u0438\u0436\u0435) \u043f\u043e\u043f\u0430\u0434\u0430\u044e\u0442 \u0432 \u043a\u043b\u044e\u0447. Index Only Scan: Postgres \u043d\u0430\u0445\u043e\u0434\u0438\u0442 \u043d\u0443\u0436\u043d\u044b\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u0437\u0430\u0431\u0438\u0440\u0430\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u00a0<strong>\u043f\u0440\u044f\u043c\u043e \u0438\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u0430<\/strong>, \u0431\u0435\u0437 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u043a heap.<\/p>\n<p>\u041f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0436\u0438\u0432\u0443\u0442 covering-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0441\u00a0<code>INCLUDE<\/code>:<\/p>\n<pre><code class=\"sql\">CREATE INDEX IX__values__object_structure_lookupON _values (_id_object, _id_structure, _array_index)INCLUDE (_Long, _Double, _DateTimeOffset, _Boolean, _Guid, _Numeric, _ListItem, _Object);CREATE INDEX IX__values__object_array_nullON _values (_id_object, _id_structure)INCLUDE (_Long, _Double, _DateTimeOffset, _Boolean, _Guid, _Numeric, _ListItem, _Object)WHERE _array_index IS NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u042d\u0442\u0438 \u0434\u0432\u0430 \u043f\u043e\u043a\u0440\u044b\u0432\u0430\u044e\u0442 \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u043f\u043e\u043b\u043e\u0436\u043d\u044b\u0439 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0439: \u00ab\u0437\u0430\u0431\u0435\u0440\u0438 \u0432\u0441\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u043e\u0434\u043d\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c\u00bb \u2014 \u0434\u043b\u044f\u00a0<code>LoadAsync&lt;T&gt;<\/code>. \u0418 \u0441\u043d\u043e\u0432\u0430 \u2014 Index Only Scan, \u043d\u043e\u043b\u044c \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0439 \u043a \u0442\u0430\u0431\u043b\u0438\u0446\u0435.<\/p>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443\u00a0<code><em>String<\/em><\/code><em>\u00a0\u0438\u0441\u043a\u043b\u044e\u0447\u0451\u043d. Btree \u0432 Postgres \u0438\u043c\u0435\u0435\u0442 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 ~2700 \u0431\u0430\u0439\u0442 \u043d\u0430 \u0441\u0442\u0440\u043e\u043a\u0443 \u0438\u043d\u0434\u0435\u043a\u0441\u0430. \u0415\u0441\u043b\u0438 \u0432\u00a0<\/em><code>String<\/code>\u00a0\u043b\u044f\u0436\u0435\u0442 JWT-payload \u0434\u043b\u0438\u043d\u043e\u0439 3 \u041a\u0411 \u2014 \u0438\u043d\u0434\u0435\u043a\u0441 \u0443\u043f\u0430\u0434\u0451\u0442 \u043d\u0430 \u0432\u0441\u0442\u0430\u0432\u043a\u0435. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438\u0434\u0443\u0442 \u0447\u0435\u0440\u0435\u0437 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 partial-\u0438\u043d\u0434\u0435\u043a\u0441 \u0441 guard&#8217;\u043e\u043c \u043f\u043e \u0434\u043b\u0438\u043d\u0435:<\/p>\n<pre><code class=\"sql\">CREATE INDEX IX__values__String_not_nullON _values (_id_structure, _id_object, _String)WHERE _String IS NOT NULL AND length(_String) &lt; 2000;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0414\u043b\u0438\u043d\u043d\u044b\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 (CMS-\u0442\u0435\u043a\u0441\u0442\u044b, base64-\u0434\u0430\u043d\u043d\u044b\u0435) \u0438\u043d\u0434\u0435\u043a\u0441 \u043d\u0435 \u043f\u043e\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u2014 \u043d\u043e \u0438\u0445 \u0438 \u043d\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u0443\u044e\u0442 \u0447\u0435\u0440\u0435\u0437\u00a0<code>=<\/code>. \u0414\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e\u0434\u0441\u0442\u0440\u043e\u043a\u0438 \u0435\u0441\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 GIN:<\/p>\n<pre><code class=\"sql\">CREATE EXTENSION IF NOT EXISTS pg_trgm;CREATE INDEX IX__values__String_patternON _values USING gin (_String gin_trgm_ops)WHERE _String IS NOT NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u042d\u0442\u043e\u0442 \u0438\u043d\u0434\u0435\u043a\u0441 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u00a0<code>LIKE<\/code>,\u00a0<code>ILIKE<\/code>,\u00a0<code>$contains<\/code>,\u00a0<code>$startsWith<\/code>,\u00a0<code>$endsWith<\/code>, regex \u2014 \u0432\u0441\u0451 \u0447\u0435\u0440\u0435\u0437\u00a0<code>pg_trgm<\/code>. \u041d\u0430 MSSQL \u0430\u043d\u0430\u043b\u043e\u0433 \u2014 full-text search \u0438\u043b\u0438 persisted computed columns \u0441 filtered index, \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u0438\u043a\u0430 \u0432 DDL \u043e\u0431\u043e\u0438\u0445 \u0434\u0432\u0438\u0436\u043a\u043e\u0432.<\/p>\n<h4>3. \u041a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438 (\u043c\u0430\u0441\u0441\u0438\u0432\u044b \u0438 \u0441\u043b\u043e\u0432\u0430\u0440\u0438)<\/h4>\n<p>\u0412 \u0441\u0442\u0430\u0442\u044c\u0435 1 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u043b\u0438 \u0440\u0435\u043b\u044f\u0446\u0438\u043e\u043d\u043d\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0439 \u2014 \u043c\u0430\u0440\u043a\u0435\u0440 + \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0441\u00a0<code><em>array<\/em>parent_id<\/code>\u00a0\u0438\u00a0<code><em>array<\/em>index<\/code>. \u041f\u043e\u0434 \u044d\u0442\u043e \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b:<\/p>\n<pre><code class=\"sql\">-- \u043e\u0431\u0445\u043e\u0434 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443CREATE INDEX IX__values__array_parent_indexON _values (_array_parent_id, _array_index);-- \u043f\u043e\u0438\u0441\u043a \u043f\u043e \u043a\u043b\u044e\u0447\u0443 \u0441\u043b\u043e\u0432\u0430\u0440\u044f (string key)CREATE INDEX IX__values__array_keyON _values (_id_structure, _array_index)WHERE _array_index IS NOT NULL;-- partial: \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u0442\u0440\u043e\u043a\u0438, \u043e\u0442\u043d\u043e\u0441\u044f\u0449\u0438\u0435\u0441\u044f \u043a \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u044f\u043cCREATE INDEX IX__values__parent_structureON _values (_array_parent_id, _id_structure)WHERE _array_parent_id IS NOT NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0422\u0440\u0435\u0442\u0438\u0439 \u2014 \u0434\u043b\u044f PRO PVT CTE \u043f\u0440\u0438 \u0447\u0442\u0435\u043d\u0438\u0438 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 Class\/Dictionary \u043f\u043e\u043b\u0435\u0439 \u0432\u0438\u0434\u0430\u00a0<code>AddressBook[\"home\"].City<\/code>.<\/p>\n<h4>4. \u0414\u0435\u0440\u0435\u0432\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 (_objects._id_parent)<\/h4>\n<p>\u0414\u0435\u0440\u0435\u0432\u043e \u2014 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 REDB: \u0440\u0430\u0437\u0434\u0435\u043b\u044b, \u043a\u0430\u0442\u0435\u0433\u043e\u0440\u0438\u0438, \u043e\u0440\u0433\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430, \u0432\u0441\u0451 \u0447\u0435\u0440\u0435\u0437\u00a0<code><em>id<\/em>parent<\/code>. \u041f\u043e\u0434 \u044d\u0442\u043e:<\/p>\n<pre><code class=\"sql\">-- \u043f\u043e\u0438\u0441\u043a \u043f\u0440\u044f\u043c\u044b\u0445 \u0434\u0435\u0442\u0435\u0439: scheme + parent \u2192 idCREATE INDEX IX__objects__scheme_parentON _objects (_id_scheme, _id_parent, _id);-- covering \u0434\u043b\u044f \u043e\u0431\u0445\u043e\u0434\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0435\u0432\u0430 (\u0441 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0432 INCLUDE)CREATE INDEX IX__objects__parent_id_descendant_lookupON _objects (_id_parent, _id_scheme)INCLUDE (_id, _id_owner, _date_create, _date_modify)WHERE _id_parent IS NOT NULL;-- partial: \u043a\u043e\u0440\u043d\u0438 (\u043e\u0431\u044a\u0435\u043a\u0442\u044b \u0431\u0435\u0437 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044f)CREATE INDEX IX__objects__root_objectsON _objects (_id_scheme, _id)WHERE _id_parent IS NULL;-- \u043e\u0431\u0440\u0430\u0442\u043d\u044b\u0439 \u043f\u0443\u0442\u044c: \u0440\u0435\u0431\u0451\u043d\u043e\u043a \u2192 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u2192 \u0441\u0445\u0435\u043c\u0430CREATE INDEX IX__objects__id_parent_schemeON _objects (_id, _id_parent, _id_scheme)WHERE _id_parent IS NOT NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><code>WhereHasAncestor<\/code>,\u00a0<code>WhereHasDescendant<\/code>,\u00a0<code>LoadTreeAsync<\/code>\u00a0\u2014 \u0432\u0441\u0435 \u0438\u0434\u0443\u0442 \u0447\u0435\u0440\u0435\u0437 \u044d\u0442\u0443 \u0447\u0435\u0442\u0432\u0451\u0440\u043a\u0443.<\/p>\n<h4>5. \u0421\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0438 \u0438 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435<\/h4>\n<pre><code class=\"sql\">-- \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e\u0434 feed \"\u043d\u043e\u0432\u0435\u0439\u0448\u0435\u0435 \u043f\u0435\u0440\u0432\u044b\u043c\"CREATE INDEX IX__objects__scheme_date_createON _objects (_id_scheme, _date_create DESC, _id);-- \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u043f\u043e \u0438\u043c\u0435\u043d\u0438 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u0432 \u0440\u0430\u043c\u043a\u0430\u0445 \u0441\u0445\u0435\u043c\u044bCREATE INDEX IX__objects__scheme_nameON _objects (_id_scheme, _name, _id);-- \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u044b\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u043e\u0431\u0449\u0438\u0439 \u043f\u043e\u0438\u0441\u043aCREATE INDEX IX__objects__name ON _objects (_name);CREATE INDEX IX__objects__hash ON _objects (_hash);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0417\u0434\u0435\u0441\u044c \u0436\u0435 \u2014 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434\u00a0<code>RedbPrimitive&lt;T&gt;<\/code>\u00a0(\u043a\u043e\u0433\u0434\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 \u0441\u0430\u043c \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043e\u043c \u2014 \u0441\u0447\u0451\u0442\u0447\u0438\u043a, \u0442\u043e\u043a\u0435\u043d, \u0435\u0434\u0438\u043d\u0438\u0447\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435):<\/p>\n<pre><code class=\"sql\">CREATE INDEX IX__objects__value_long ON _objects (_value_long) WHERE _value_long IS NOT NULL;CREATE INDEX IX__objects__value_string ON _objects (_value_string) WHERE _value_string IS NOT NULL;CREATE INDEX IX__objects__value_guid ON _objects (_value_guid) WHERE _value_guid IS NOT NULL;CREATE INDEX IX__objects__value_datetime ON _objects (_value_datetime) WHERE _value_datetime IS NOT NULL;CREATE INDEX IX__objects__value_numeric ON _objects (_value_numeric) WHERE _value_numeric IS NOT NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412\u0441\u0435 \u2014 partial, \u0430\u043a\u0442\u0438\u0432\u043d\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0441\u0442\u0440\u043e\u043a, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u043e.<\/p>\n<h4>6. \u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0438 \u0441\u0445\u0435\u043c\u044b (_structures,\u00a0_schemes)<\/h4>\n<p>\u042d\u0442\u043e \u00ab\u0445\u043e\u043b\u043e\u0434\u043d\u044b\u0435\u00bb \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u2014 \u0438\u0445 \u0440\u0430\u0437\u043c\u0435\u0440 \u043c\u0435\u043d\u044c\u0448\u0435\u00a0<code>_values<\/code>\u00a0\u043d\u0430 \u043f\u043e\u0440\u044f\u0434\u043a\u0438, \u0438 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u0438\u0434\u0443\u0442 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u043c \u043f\u0440\u0438 \u0447\u0442\u0435\u043d\u0438\u0438 \u043a\u044d\u0448\u0430 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445. \u041d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u043e\u043d\u0438 \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0431\u044b\u0441\u0442\u0440\u044b \u0434\u043e \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434:<\/p>\n<pre><code class=\"sql\">-- covering \u043f\u043e\u0434 ORDER BY field nameCREATE INDEX IX__structures__nameON _structures (_name)INCLUDE (_id, _id_type, _collection_type, _id_scheme);-- covering \u0434\u043b\u044f \u043b\u0443\u043a\u0430\u043f\u0430 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u043f\u043e IDCREATE INDEX IX__structures__id_lookupON _structures (_id)INCLUDE (_id_type, _name, _collection_type, _id_scheme);-- partial: \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u043e\u043d\u043d\u044b\u0445 \u0438 \u043d\u0435\u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u043e\u043d\u043d\u044b\u0445CREATE INDEX IX__structures__not_collectionON _structures (_id, _name, _id_scheme)WHERE _collection_type IS NULL;CREATE INDEX IX__structures__collectionON _structures (_id, _id_scheme, _collection_type)WHERE _collection_type IS NOT NULL;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445 DDL \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043e: \u044d\u0442\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0443\u0431\u0438\u0440\u0430\u044e\u0442 Seq Scan \u043d\u0430 InitPlan \u0438 EXISTS-\u043f\u043e\u0434\u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445 \u0432 \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u0438 hierarchical properties (<code>build_hierarchical_properties_optimized<\/code>), \u0441\u043d\u0438\u0436\u0430\u044f cost \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u0441 6.10 \u0434\u043e 4.29 (-30%).<\/p>\n<h4>\u0427\u0442\u043e \u0431\u044b\u043b\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u043e<\/h4>\n<p>\u0412\u00a0<code>redbPostgre.sql<\/code>\u00a0\u0435\u0441\u0442\u044c \u0437\u0430\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0431\u043b\u043e\u043a:<\/p>\n<pre><code class=\"sql\">-- ============================================-- REMOVED REDUNDANT INDEXES (migration_drop_redundant_indexes.sql)-- Reason: Covered by composite index IX__values__structure_object_lookup-- Facet search ALWAYS filters by (_id_structure, _id_object) BEFORE value-- ============================================-- CREATE INDEX \"IX__values__String\" ON _values (_String) ...;-- CREATE INDEX \"IX__values__Long\" ON _values (_Long) ...;-- CREATE INDEX \"IX__values__Guid\" ON _values (_Guid) ...;-- ...<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u042d\u0442\u043e \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0447\u0438\u0441\u0442\u043a\u0438 \u043f\u0440\u044f\u043c\u043e \u0432 \u0444\u0430\u0439\u043b\u0435 \u0441\u0445\u0435\u043c\u044b. \u0420\u0430\u043d\u043d\u0438\u0435 \u0432\u0435\u0440\u0441\u0438\u0438 REDB \u0441\u0442\u0430\u0432\u0438\u043b\u0438 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0443\u044e \u043a\u043e\u043b\u043e\u043d\u043a\u0443. \u041d\u0430 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0435 \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u044d\u0442\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0435 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u0443\u044e\u0442\u0441\u044f: facet-\u0437\u0430\u043f\u0440\u043e\u0441\u00a0<strong>\u0432\u0441\u0435\u0433\u0434\u0430<\/strong>\u00a0\u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441\u00a0<code><em>id<\/em>structure<\/code>, \u0430 \u043d\u0435 \u0441 \u0441\u0430\u043c\u043e\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f. \u041a\u043e\u043c\u043f\u043e\u0437\u0438\u0442\u043d\u044b\u0439\u00a0<code>(_id_structure, <em>id<\/em>object, _Long, ...)<\/code>\u00a0\u043f\u043e\u0433\u043b\u043e\u0449\u0430\u0435\u0442 \u0438\u0445 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e. \u041b\u0438\u0448\u043d\u0435\u0435 \u0443\u0431\u0440\u0430\u043d\u043e.<\/p>\n<hr\/>\n<h3>\u041f\u043e\u0447\u0435\u043c\u0443 \u0442\u0430\u043a \u0431\u044b\u0441\u0442\u0440\u043e \u043d\u0430 \u043f\u0440\u043e\u0434\u0435<\/h3>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/c8f\/bd6\/34d\/c8fbd634d7986c5a841dc1af56a08639.png\" alt=\"\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\" title=\"\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\" width=\"1147\" height=\"653\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/c8f\/bd6\/34d\/c8fbd634d7986c5a841dc1af56a08639.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/c8f\/bd6\/34d\/c8fbd634d7986c5a841dc1af56a08639.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432<\/figcaption><\/div>\n<\/figure>\n<p>\u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u044b \u2014 \u044d\u0442\u043e \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u0430 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u0430. \u0412\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u043b\u043e\u0432\u0438\u043d\u0430 \u2014 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0446\u0438\u0444\u0440\u044b. \u041a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u043b\u043e\u0433 TSUM, \u0442\u0438\u043f\u043e\u0432\u043e\u0439 \u0446\u0438\u043a\u043b \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043a\u0430\u0437\u043e\u0432:<\/p>\n<pre><code>[TSUM] orders=999 routes(+2 ~30 =967) drivers(+0 ~0) vehicles(+0 ~0)       sync=482 query=139 save=154 total=991ms<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0420\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u043a\u0430:<\/p>\n<ul>\n<li>\n<p><strong>999 \u0437\u0430\u043a\u0430\u0437\u043e\u0432<\/strong>\u00a0\u043f\u0440\u0438\u0448\u043b\u043e \u043e\u0434\u043d\u043e\u0439 XML-\u043f\u0430\u0447\u043a\u043e\u0439 \u0438\u0437 SAP S\/4 (\u0445\u0440\u0430\u043d\u0438\u043c\u0430\u044f \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430\u00a0<code>usp_TsUM_MonitoringReport_xml<\/code>).<\/p>\n<\/li>\n<li>\n<p><strong>routes(+2 ~30 =967)<\/strong>: \u0438\u0437 999 \u043f\u0440\u0438\u0448\u0435\u0434\u0448\u0438\u0445 \u2014 2 \u043d\u043e\u0432\u044b\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u0430, 30 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u043e\u0441\u044c,\u00a0<strong>967 \u043d\u0435 \u0442\u0440\u043e\u043d\u0443\u043b\u0438 \u0432\u043e\u043e\u0431\u0449\u0435<\/strong>\u00a0(\u0441\u043e\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u0435 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u043e\u0441\u044c).<\/p>\n<\/li>\n<li>\n<p><strong>drivers\/vehicles (+0 ~0)<\/strong>: \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438 \u0432\u043e\u0434\u0438\u0442\u0435\u043b\u0435\u0439 \u0438 \u043c\u0430\u0448\u0438\u043d \u0432 \u044d\u0442\u043e\u0439 \u043f\u0430\u0447\u043a\u0435 \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439.<\/p>\n<\/li>\n<li>\n<p><strong>sync = 482 \u043c\u0441<\/strong>\u00a0\u2014 \u044d\u0442\u043e\u00a0<strong>\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u044f \u0421\u041f\u0420\u0410\u0412\u041e\u0427\u041d\u0418\u041a\u041e\u0412<\/strong>\u00a0(<code>DictionarySyncService.SyncFromOrdersAsync<\/code>): \u043f\u0440\u043e\u0439\u0442\u0438 \u043f\u043e \u0432\u0441\u0435\u043c 999 \u0437\u0430\u043a\u0430\u0437\u0430\u043c, \u0441\u0432\u0435\u0440\u0438\u0442\u044c \u0432\u043e\u0434\u0438\u0442\u0435\u043b\u0435\u0439\/\u043c\u0430\u0448\u0438\u043d\u044b\/\u0420\u0426\/\u0442\u0438\u043f\u044b \u0431\u0438\u0437\u043d\u0435\u0441\u0430\/\u0441\u0442\u0430\u0442\u0443\u0441\u044b \u0434\u043e\u0441\u0442\u0430\u0432\u043a\u0438 \u0441 REDB-\u0441\u043f\u0438\u0441\u043a\u0430\u043c\u0438, \u043f\u0440\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0434\u043e\u043a\u0438\u043d\u0443\u0442\u044c \u043d\u043e\u0432\u044b\u0435\u00a0<code>list_items<\/code>. \u042d\u0442\u043e\u00a0<strong>\u043d\u0435 sync \u0441\u0445\u0435\u043c<\/strong>.<\/p>\n<\/li>\n<li>\n<p><strong>query = 139 \u043c\u0441<\/strong>\u00a0\u2014\u00a0<strong>\u043e\u0434\u0438\u043d SELECT<\/strong>\u00a0\u0432 REDB:\u00a0<code>WhereRedb(o =&gt; codes.Contains(o.ValueString))<\/code>\u00a0\u2014 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0430\u00a0<strong>\u0432\u0441\u0435\u0445 999<\/strong>\u00a0\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u043e\u0432 \u043f\u043e \u0438\u0445 \u043a\u043e\u0434\u0430\u043c \u043e\u0434\u043d\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c.<\/p>\n<\/li>\n<li>\n<p><strong>save = 154 \u043c\u0441<\/strong>\u00a0\u2014\u00a0<code>SaveAsync<\/code>\u00a0\u0434\u043b\u044f\u00a0<strong>32 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432<\/strong>\u00a0(2 created + 30 updated). 967 \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u0441\u044e\u0434\u0430 \u043d\u0435 \u043f\u043e\u043f\u0430\u043b\u0438.<\/p>\n<\/li>\n<li>\n<p>\u041e\u043a\u0440\u0443\u0436\u0435\u043d\u0438\u0435:\u00a0<strong>2 \u044f\u0434\u0440\u0430<\/strong>, default\u00a0<code>shared_buffers<\/code>,\u00a0<code>pg_prewarm<\/code>\u00a0\u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f, \u043a\u044d\u0448\u0430 \u0443\u0440\u043e\u0432\u043d\u044f redb-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430 \u043d\u0435\u0442.<\/p>\n<\/li>\n<\/ul>\n<blockquote>\n<p>\u0412\u0430\u0436\u043d\u0430\u044f \u043e\u0433\u043e\u0432\u043e\u0440\u043a\u0430: \u0441\u0445\u0435\u043c\u0430-sync (<code>SyncSchemeAsync&lt;T&gt;<\/code>\u00a0\u2014 \u0442\u043e, \u0447\u0442\u043e \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0435\u0442\u00a0<code><em>structure<\/em>hash<\/code>\u00a0\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u00a0<code><em>scheme<\/em>metadata_cache<\/code>) \u2014\u00a0<strong>\u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439<\/strong>\u00a0\u044d\u0442\u0430\u043f, \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043e\u0434\u043d\u043e\u043a\u0440\u0430\u0442\u043d\u043e \u043f\u0440\u0438 \u0441\u0442\u0430\u0440\u0442\u0435 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430 \u0434\u043e \u043d\u0430\u0447\u0430\u043b\u0430 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043a\u0430\u0437\u043e\u0432. \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u043b\u043e\u0433\u0430 \u0435\u0433\u043e \u043d\u0435\u0442 \u0432\u043e\u043e\u0431\u0449\u0435. \u0422\u043e, \u0447\u0442\u043e \u0437\u0434\u0435\u0441\u044c \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f\u00a0<code>sync<\/code>, \u2014 \u044d\u0442\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u044b\u0445 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u043e\u0432, \u043d\u0435 \u0441\u0445\u0435\u043c.<\/p>\n<\/blockquote>\n<p>\u0420\u0430\u0437\u0431\u0435\u0440\u0451\u043c, \u0447\u0442\u043e \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u044d\u0442\u0438\u043c\u0438 \u0446\u0438\u0444\u0440\u0430\u043c\u0438.<\/p>\n<h4>Query: 139 \u043c\u0441 \u043d\u0430 999 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u043e\u0434\u043d\u0438\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c<\/h4>\n<pre><code>[TSUM] orders=999 routes(+2 ~30 =967) drivers(+0 ~0) vehicles(+0 ~0) sync=482 query=139 save=154 total=991ms<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0421\u0430\u043c\u043e\u0435 \u0432\u043f\u0435\u0447\u0430\u0442\u043b\u044f\u044e\u0449\u0435\u0435 \u0447\u0438\u0441\u043b\u043e \u0432 \u043b\u043e\u0433\u0435. \u042d\u0442\u043e \u043d\u0435 999 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445\u00a0<code>LoadAsync<\/code>\u00a0\u2014 \u044d\u0442\u043e\u00a0<strong>\u043e\u0434\u0438\u043d<\/strong>\u00a0facet-\u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u0438\u0434\u0430:<\/p>\n<pre><code>var existing = await redb.Query&lt;TransportationRoute&gt;()    .WhereRedb(o =&gt; codes.Contains(o.ValueString!))    .ToListAsync();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u043e\u0442\u043e\u0440\u044b\u0439 \u0442\u0440\u0430\u043d\u0441\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 SQL \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a (\u0443\u043f\u0440\u043e\u0449\u0451\u043d\u043d\u043e):<\/p>\n<pre><code class=\"sql\">-- \u043d\u0430\u0439\u0442\u0438 \u0432\u0441\u0435 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u044b, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 _value_string \u2208 \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u0437 999 \u043a\u043e\u0434\u043e\u0432SELECT o.* FROM _objects oWHERE o._id_scheme = @routeSchemeId  AND o._value_string = ANY(@codes);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u2014 \u043e\u0434\u0438\u043d \u0431\u0430\u0442\u0447-\u0437\u0430\u043f\u0440\u043e\u0441 \u0437\u0430\u00a0<code><em>values<\/em><\/code><em>\u00a0\u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u043d\u0430\u0439\u0434\u0435\u043d\u043d\u044b\u0445 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0447\u0435\u0440\u0435\u0437\u00a0<\/em><code><em>IX<\/em>_values__object_array_null<\/code>\u00a0(covering INCLUDE) \u2014 Index Only Scan, heap \u043d\u0435 \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f. \u041d\u0430 \u0432\u044b\u0445\u043e\u0434\u0435 \u2014 999 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0433\u0438\u0434\u0440\u0430\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445\u00a0<code>RedbObject&lt;TransportationRoute&gt;<\/code>\u00a0\u0441\u043e \u0432\u0441\u0435\u043c\u0438 ~50 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u043c\u0438 \u043a\u0430\u0436\u0434\u043e\u0433\u043e, \u0432\u043a\u043b\u044e\u0447\u0430\u044f ListItem-\u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438.<\/p>\n<p>139 \u043c\u0441 \/ 999 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 =\u00a0<strong>0.14 \u043c\u0441 \u043d\u0430 \u043e\u0431\u044a\u0435\u043a\u0442<\/strong>, \u043d\u043e \u044d\u0442\u043e \u0431\u0443\u0445\u0433\u0430\u043b\u0442\u0435\u0440\u0441\u043a\u0430\u044f \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u043a\u0430 \u2014 \u0440\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u043e\u0438\u043c\u043e\u0441\u0442\u044c \u044d\u0442\u043e \u0434\u0432\u0430 SQL round-trip&#8217;\u0430 (\u043e\u0434\u0438\u043d \u0437\u0430\u00a0<code><em>objects<\/em><\/code><em>, \u043e\u0434\u0438\u043d \u0437\u0430\u00a0<\/em><code>values<\/code>) \u043f\u043b\u044e\u0441 \u0433\u0438\u0434\u0440\u0430\u0442\u0430\u0446\u0438\u044f \u0432 C#.<\/p>\n<p>\u041d\u0438\u043a\u0430\u043a\u0438\u0445 N+1. \u041d\u0438\u043a\u0430\u043a\u0438\u0445 Include-\u043e\u0432. ListItem-\u0441\u0441\u044b\u043b\u043a\u0438 \u0440\u0430\u0437\u0440\u0435\u0448\u0430\u044e\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437\u00a0<code>RefDataCache<\/code>\u00a0\u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u2014 \u043f\u043e\u044d\u0442\u043e\u043c\u0443\u00a0<code>Vehicle<\/code>,\u00a0<code>Driver<\/code>,\u00a0<code>ShippingPoint<\/code>\u00a0\u043f\u043e\u043b\u044f \u0437\u0430\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0431\u0435\u0437 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432.<\/p>\n<h4>Save: 154 \u043c\u0441 \u043d\u0430 32 \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u043e\u0431\u044a\u0435\u043a\u0442\u0430<\/h4>\n<p>\u0417\u0434\u0435\u0441\u044c \u0434\u0432\u0430 \u043c\u043e\u043c\u0435\u043d\u0442\u0430, \u0438 \u043e\u0431\u0430 \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u044b.<\/p>\n<p><strong>\u041f\u0435\u0440\u0432\u044b\u0439 \u2014 change tracking \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f<\/strong>. \u041f\u0435\u0440\u0435\u0434\u00a0<code>SaveAsync<\/code>\u00a0\u043a\u0430\u0436\u0434\u044b\u0439 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0439 \u043c\u0430\u0440\u0448\u0440\u0443\u0442 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u0447\u0435\u0440\u0435\u0437\u00a0<code>ComputeHash()<\/code>:<\/p>\n<pre><code>var hashBefore = obj.ComputeHash();EnrichRouteFromOrder(obj.Props, routeProps);if (obj.ComputeHash() != hashBefore){    toSave.Add(obj);  \/\/ \u0434\u0430\u043d\u043d\u044b\u0435 \u0440\u0435\u0430\u043b\u044c\u043d\u043e \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c \u2014 \u043a\u043b\u0430\u0434\u0451\u043c \u043d\u0430 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435    updatedCount++;}else{    skippedCount++;   \/\/ \u0442\u043e\u0442 \u0436\u0435 \u0431\u0430\u0439\u0442-\u0432-\u0431\u0430\u0439\u0442 \u2014 \u043d\u0435 \u0442\u0440\u043e\u0433\u0430\u0435\u043c \u0411\u0414 \u0432\u043e\u043e\u0431\u0449\u0435}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418\u0437 999 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u044b\u0445 \u0437\u0430\u043a\u0430\u0437\u043e\u0432 \u2014\u00a0<strong>967 \u043f\u0440\u043e\u043f\u0443\u0449\u0435\u043d\u044b<\/strong>\u00a0\u0438\u043c\u0435\u043d\u043d\u043e \u0442\u0430\u043a. \u041e\u043d\u0438 \u043d\u0435 \u0434\u043e\u0448\u043b\u0438 \u0434\u043e\u00a0<code><em>objects<\/em><\/code><em>\/<\/em><code>values<\/code>, \u043d\u0435 \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u043d\u0438 \u043e\u0434\u043d\u043e\u0439 DML-\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438. \u042d\u0442\u043e \u043d\u0435 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u044f\u0434\u0440\u0430 REDB \u2014 \u044d\u0442\u043e \u043f\u0430\u0442\u0442\u0435\u0440\u043d \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430, \u043d\u043e REDB \u0435\u0433\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0434\u0435\u0448\u0451\u0432\u044b\u043c\u00a0<code>ComputeHash()<\/code>\u00a0\u043f\u043e\u0432\u0435\u0440\u0445 Props.<\/p>\n<p><strong>\u0412\u0442\u043e\u0440\u043e\u0439 \u2014 bulk-save \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438<\/strong>. \u041e\u0441\u0442\u0430\u0432\u0448\u0438\u0435\u0441\u044f 32 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u0443\u0445\u043e\u0434\u044f\u0442 \u043e\u0434\u043d\u0438\u043c \u0432\u044b\u0437\u043e\u0432\u043e\u043c:<\/p>\n<pre><code>await redb.SaveAsync(toSave);   \/\/ toSave: List&lt;IRedbObject&gt;, 32 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418 \u0432\u043e\u0442 \u0447\u0442\u043e \u0432\u043d\u0443\u0442\u0440\u0438. \u0421\u043d\u0430\u0447\u0430\u043b\u0430\u00a0<code><em>objects<\/em><\/code><em>\u00a0\u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u0443\u0435\u0442\u0441\u044f \u0431\u0430\u0442\u0447\u0435\u043c \u2014 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 32 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u043e\u0434\u043d\u0438\u043c INSERT\/UPDATE-\u043f\u0440\u043e\u0445\u043e\u0434\u043e\u043c (\u0434\u043b\u044f \u043d\u043e\u0432\u044b\u0445 \u2014 \u043e\u0434\u0438\u043d COPY\/<\/em><code><em>UNNEST<\/em><\/code><em>-INSERT, \u0434\u043b\u044f \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u2014 \u0431\u0430\u0442\u0447\u0435\u0432\u044b\u0439 UPDATE). \u041f\u043e\u0442\u043e\u043c \u2014\u00a0<\/em><code>values<\/code>: \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u043e\u0433\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u0430\u0431\u043e\u0440 \u0441\u0442\u0440\u043e\u043a \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439, \u0438 \u0442\u043e\u0436\u0435 \u043d\u0435 \u043f\u043e\u0441\u0442\u0440\u043e\u0447\u043d\u043e, \u0430 \u043e\u0434\u043d\u0438\u043c bulk-\u0432\u044b\u0437\u043e\u0432\u043e\u043c \u0447\u0435\u0440\u0435\u0437 COPY protocol Postgres.\u00a0<strong>\u0412\u0441\u0451 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438<\/strong>\u00a0\u2014\u00a0<code><em>objects<\/em><\/code><em>\u00a0\u0438\u00a0<\/em><code>values<\/code>\u00a0\u0444\u0438\u043a\u0441\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u043e.<\/p>\n<p>COPY protocol \u0432\u0430\u0436\u0435\u043d. \u042d\u0442\u043e \u043f\u043e\u0442\u043e\u0447\u043d\u044b\u0439 \u0431\u0438\u043d\u0430\u0440\u043d\u044b\u0439 \u043f\u0440\u043e\u0442\u043e\u043a\u043e\u043b, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 N \u0441\u0442\u0440\u043e\u043a \u0431\u0435\u0437 round-trip \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u2014 \u0434\u0440\u0430\u0439\u0432\u0435\u0440 \u043f\u0438\u0448\u0435\u0442 \u0432 \u0441\u043e\u043a\u0435\u0442 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043a. \u041d\u0430 32 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u00d7 ~50 \u0441\u0432\u043e\u0439\u0441\u0442\u0432 = ~1600 \u0441\u0442\u0440\u043e\u043a \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u2192 \u043e\u0434\u043d\u0430 COPY-\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f \u0432\u043c\u0435\u0441\u0442\u043e 1600 INSERT&#8217;\u043e\u0432. Btree-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u043b\u0443\u0447\u0430\u044e\u0442 \u0441\u0432\u043e\u0439 \u0431\u0430\u0442\u0447 \u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0430\u043c\u043e\u0440\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e.<\/p>\n<p>\u041f\u043e\u044d\u0442\u043e\u043c\u0443 154 \u043c\u0441 \u043d\u0430 32 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 (~4.8 \u043c\u0441 \u043d\u0430 \u043e\u0431\u044a\u0435\u043a\u0442 \u043f\u043e\u043b\u043d\u043e\u0439 \u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0438\u0441\u0438) \u2014 \u044d\u0442\u043e \u043d\u0435 \u00ab\u0434\u0432\u0438\u0436\u043e\u043a \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u044b\u0439\u00bb, \u044d\u0442\u043e \u00ab\u0434\u0432\u0438\u0436\u043e\u043a \u043d\u0435 \u0434\u0435\u043b\u0430\u0435\u0442 \u043b\u0438\u0448\u043d\u0435\u0433\u043e\u00bb. Bulk \u0442\u0430\u043c, \u0433\u0434\u0435 \u043c\u043e\u0436\u043d\u043e bulk; \u0440\u0430\u043d\u043d\u0438\u0439 skip \u0442\u0430\u043c, \u0433\u0434\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c.<\/p>\n<h4>Sync: 482 \u043c\u0441 \u2014 \u0447\u0442\u043e \u044d\u0442\u043e \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435<\/h4>\n<p>482 \u043c\u0441 \u2014 \u0441\u0430\u043c\u0430\u044f \u00ab\u0442\u043e\u043b\u0441\u0442\u0430\u044f\u00bb \u0441\u0442\u0440\u043e\u043a\u0430 \u0432 \u043b\u043e\u0433\u0435, \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u0435\u0451 \u043e\u0431\u044b\u0447\u043d\u043e \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0438\u043d\u0442\u0435\u0440\u043f\u0440\u0435\u0442\u0438\u0440\u0443\u044e\u0442. \u042d\u0442\u043e\u00a0<strong>\u043d\u0435<\/strong>\u00a0\u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0430\u0446\u0438\u044f \u0441\u0445\u0435\u043c \u2014 sync \u0441\u0445\u0435\u043c \u0443\u0436\u0435 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u0451\u043b \u043f\u0440\u0438 \u0441\u0442\u0430\u0440\u0442\u0435 Worker&#8217;\u0430 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043f\u043e\u0448\u043b\u0438 \u0437\u0430\u043a\u0430\u0437\u044b. 482 \u043c\u0441 \u2014 \u044d\u0442\u043e\u00a0<code>DictionarySyncService.SyncFromOrdersAsync<\/code>:<\/p>\n<ol>\n<li>\n<p>\u041f\u044f\u0442\u044c \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u044b\u0445 \u0437\u0430\u0433\u0440\u0443\u0437\u043e\u043a \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u043e\u0432 \u0438\u0437 REDB:\u00a0<code>Drivers<\/code>,\u00a0<code>Vehicles<\/code>,\u00a0<code>ShippingPoints<\/code>,\u00a0<code>BusinessTypes<\/code>,\u00a0<code>DeliveryStatuses<\/code>\u00a0\u2014 \u0447\u0435\u0440\u0435\u0437\u00a0<code>redb.ListProvider.GetListByNameWithItemsAsync(...)<\/code>. \u041f\u043e\u0434\u0433\u0440\u0443\u0436\u0430\u044e\u0442\u0441\u044f\u00a0<code><em>lists<\/em><\/code><em>\u00a0+ \u0432\u0441\u0435 \u0438\u0445\u00a0<\/em><code>list_items<\/code>.<\/p>\n<\/li>\n<li>\n<p>\u041f\u0440\u043e\u0445\u043e\u0434 \u043f\u043e 999 \u0437\u0430\u043a\u0430\u0437\u0430\u043c: \u043a\u0430\u0436\u0434\u044b\u0439\u00a0<code>DriverId<\/code>,\u00a0<code>CarId<\/code>,\u00a0<code>ShippingPoint<\/code>,\u00a0<code>BusinessTypes<\/code>\u00a0\u0441\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u0441 \u0443\u0436\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u043c\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0430. \u0415\u0441\u043b\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043d\u043e\u0432\u043e\u0435 \u2014 \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442\u0441\u044f upsert.<\/p>\n<\/li>\n<li>\n<p>\u0415\u0441\u043b\u0438 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c \u2014 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435\u00a0<code>RefDataCache<\/code>\u00a0(\u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 in-memory \u043a\u044d\u0448, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u0438 \u043c\u0430\u043f\u043f\u0438\u043d\u0433\u0435 Order \u2192 RouteProps \u043d\u0435 \u0445\u043e\u0434\u0438\u0442\u044c \u0432 \u0411\u0414 \u043f\u043e\u0432\u0442\u043e\u0440\u043d\u043e).<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u044d\u0442\u043e\u0439 \u043f\u0430\u0447\u043a\u0435 \u043f\u0440\u0438\u0448\u043b\u0438 \u00ab\u043d\u0443\u043b\u0435\u0432\u044b\u0435\u00bb \u0434\u0435\u043b\u044c\u0442\u044b \u043f\u043e \u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044f\u043c \u0438 \u043c\u0430\u0448\u0438\u043d\u0430\u043c (<code>+0 ~0<\/code>), \u043d\u043e 482 \u043c\u0441 \u0443\u0448\u043b\u043e \u043d\u0430\u00a0<strong>\u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443<\/strong>, \u0447\u0442\u043e \u043e\u043d\u0438 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c \u2014 \u044d\u0442\u043e 999 \u0441\u0442\u0440\u043e\u043a \u0441\u0432\u0435\u0440\u043a\u0438 \u043f\u0440\u043e\u0442\u0438\u0432 \u0442\u044b\u0441\u044f\u0447 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 list_items \u043f\u043e \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u043c \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0430\u043c.<\/p>\n<p>\u042d\u0442\u043e\u00a0<strong>\u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u043e\u0439<\/strong>\u00a0sync \u2014 \u043e\u043d \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u0438\u0442 \u043b\u043e\u0433\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u043c\u0443 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0443 TSUM, \u043d\u0435 \u0434\u0432\u0438\u0436\u043a\u0443 REDB. \u041d\u043e \u043e\u043d \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0432\u0430\u0436\u043d\u043e\u0435: \u0434\u0430\u0436\u0435 \u043a\u043e\u0433\u0434\u0430 \u00ab\u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0438\u0442\u044c, \u0447\u0442\u043e \u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0435 \u043d\u0430\u0434\u043e\u00bb \u0434\u043e\u0440\u043e\u0436\u0435, \u0447\u0435\u043c \u0441\u0430\u043c save (482 \u043c\u0441 sync vs 154 \u043c\u0441 save), \u043e\u0431\u0449\u0438\u0439 \u0446\u0438\u043a\u043b \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e \u0443\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0441\u0435\u043a\u0443\u043d\u0434\u0443 \u043d\u0430 \u0442\u044b\u0441\u044f\u0447\u0435 \u0437\u0430\u043a\u0430\u0437\u043e\u0432.<\/p>\n<p>Sync \u0441\u0445\u0435\u043c \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f. \u041d\u0430 \u0445\u043e\u043b\u043e\u0434\u043d\u043e\u043c \u0441\u0442\u0430\u0440\u0442\u0435 Worker&#8217;\u0430 \u2014 \u0434\u0435\u0441\u044f\u0442\u043a\u0438-\u0441\u043e\u0442\u043d\u0438 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434 \u043e\u0434\u043d\u043e\u043a\u0440\u0430\u0442\u043d\u043e (32 \u0441\u0445\u0435\u043c\u044b, \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u0435 \u0445\u0435\u0448\u0435\u0439). \u041f\u0440\u0438 \u0433\u043e\u0440\u044f\u0447\u0435\u043c \u0440\u0435\u0441\u0442\u0430\u0440\u0442\u0435 \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0432 \u043c\u043e\u0434\u0435\u043b\u044f\u0445 \u2014 \u0435\u0434\u0438\u043d\u0438\u0446\u044b \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434. \u042d\u0442\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442\u00a0<strong>\u0434\u043e<\/strong>\u00a0\u043f\u0435\u0440\u0432\u043e\u0433\u043e\u00a0<code>[TSUM]<\/code>-\u043b\u043e\u0433\u0430 \u0438 \u0432 \u0441\u0442\u0440\u043e\u043a\u0435 \u0446\u0438\u043a\u043b\u0430 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043d\u0435 \u0443\u0447\u0438\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f.<\/p>\n<h4>\u041e\u0442\u0432\u0435\u0442 \u0441\u043a\u0435\u043f\u0442\u0438\u043a\u0443 \u043f\u0440\u043e 9.7M \u0441\u0442\u0440\u043e\u043a<\/h4>\n<p>\u0413\u043b\u0430\u0432\u043d\u043e\u0435 \u0432\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435, \u0441 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u043b\u0438 \u0441\u0442\u0430\u0442\u044c\u044e: \u00ab\u043a\u0430\u043a \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u043f\u0440\u0438 \u0442\u0430\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u00bb. \u041e\u0442\u0432\u0435\u0442:\u00a0<strong>\u0434\u0432\u0438\u0436\u043e\u043a \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0441\u043a\u0430\u043d\u0438\u0440\u0443\u0435\u0442\u00a0<\/strong><code><strong>_values<\/strong><\/code><strong>\u00a0\u0446\u0435\u043b\u0438\u043a\u043e\u043c<\/strong>. \u041b\u044e\u0431\u043e\u0439 \u0437\u0430\u043f\u0440\u043e\u0441:<\/p>\n<ul>\n<li>\n<p>\u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u043b\u0438\u0431\u043e \u0441 PK (<code>LoadAsync<\/code>\u00a0\u043f\u043e ID) \u2014 O(log n) \u043f\u043e \u0434\u0435\u0440\u0435\u0432\u0443 \u0438\u043d\u0434\u0435\u043a\u0441\u0430,<\/p>\n<\/li>\n<li>\n<p>\u043b\u0438\u0431\u043e \u0441\u00a0<code><em>id<\/em>scheme<\/code>\u00a0+\u00a0<code><em>value<\/em>string<\/code>\u00a0\u0434\u043b\u044f facet&#8217;\u0430 \u0447\u0435\u0440\u0435\u0437\u00a0<code>RedbPrimitive<\/code>-\u043a\u043e\u043b\u043e\u043d\u043a\u0443, \u043a\u0430\u043a \u0432 TSUM-\u043a\u0435\u0439\u0441\u0435 \u0432\u044b\u0448\u0435 \u2014 Index Only Scan \u043f\u043e\u00a0<code>IX__objects__value_string<\/code>,<\/p>\n<\/li>\n<li>\n<p>\u043b\u0438\u0431\u043e \u0441\u00a0<code><em>id<\/em>structure<\/code>\u00a0(facet search \u043f\u043e \u043e\u0431\u044b\u0447\u043d\u043e\u043c\u0443 \u043f\u043e\u043b\u044e) \u2014 \u043e\u0442\u0441\u0435\u043a\u0430\u0435\u0442 ~99.75% \u0441\u0442\u0440\u043e\u043a \u0441\u0440\u0430\u0437\u0443: \u043d\u0430 401 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0435 \u043a\u0430\u0436\u0434\u044b\u0439\u00a0<code><em>id<\/em>structure<\/code>\u00a0\u0438\u043c\u0435\u0435\u0442 \u0432 \u0441\u0440\u0435\u0434\u043d\u0435\u043c ~24K \u0441\u0442\u0440\u043e\u043a \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0438\u0437 9.7M \u043e\u0431\u0449\u0435\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430,<\/p>\n<\/li>\n<li>\n<p>\u043b\u0438\u0431\u043e \u0441\u00a0<code><em>id<\/em>object<\/code>\u00a0(LoadAsync \u2014 \u0432\u0441\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u0430) \u2014 \u043e\u0442\u0441\u0435\u043a\u0430\u0435\u0442 \u0435\u0449\u0451 \u0430\u0433\u0440\u0435\u0441\u0441\u0438\u0432\u043d\u0435\u0435, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0443 \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439, \u043d\u0435 \u0442\u044b\u0441\u044f\u0447\u0438.<\/p>\n<\/li>\n<\/ul>\n<p>\u041e\u0431\u044a\u0451\u043c \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0432 \u0441\u0442\u0440\u043e\u043a\u0430\u0445 \u0432\u043b\u0438\u044f\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u0440\u0430\u0437\u043c\u0435\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u0432 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u0445. Btree \u0432 Postgres \u0438\u043c\u0435\u0435\u0442 \u0444\u0430\u043a\u0442\u043e\u0440 \u0432\u0435\u0442\u0432\u043b\u0435\u043d\u0438\u044f \u043f\u043e\u0440\u044f\u0434\u043a\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u043e\u0442\u0435\u043d \u2014 \u043d\u0430 9.7M \u0441\u0442\u0440\u043e\u043a \u044d\u0442\u043e \u0433\u043b\u0443\u0431\u0438\u043d\u0430 4-5 \u0443\u0440\u043e\u0432\u043d\u0435\u0439. \u041f\u043e\u0438\u0441\u043a \u043f\u043e \u0442\u0430\u043a\u043e\u043c\u0443 \u0434\u0435\u0440\u0435\u0432\u0443 \u2014 \u043b\u043e\u0433\u0430\u0440\u0438\u0444\u043c\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0437\u0430\u043c\u0435\u0434\u043b\u0435\u043d\u0438\u0435, \u043d\u0435 \u043b\u0438\u043d\u0435\u0439\u043d\u043e\u0435.<\/p>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/3f7\/245\/305\/3f724530522b885d55b2028b5a5a300f.png\" alt=\"\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\" title=\"\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\" width=\"1083\" height=\"630\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/3f7\/245\/305\/3f724530522b885d55b2028b5a5a300f.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/3f7\/245\/305\/3f724530522b885d55b2028b5a5a300f.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432<\/figcaption><\/div>\n<\/figure>\n<hr\/>\n<h3>\u00ab\u041d\u0443\u0436\u043d\u043e\u0435 \u043d\u0435 \u0432\u0441\u0435\u0433\u0434\u0430 \u043d\u0443\u0436\u043d\u043e\u00bb: \u044d\u043a\u0441\u043f\u043b\u0443\u0430\u0442\u0430\u0446\u0438\u044f \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043f\u043e\u0441\u043b\u0435 \u0441\u0442\u0430\u0431\u0438\u043b\u0438\u0437\u0430\u0446\u0438\u0438<\/h3>\n<p>\u0412 DDL\u00a0<code>redbPostgre.sql<\/code>\u00a0\u0437\u0430\u0448\u0438\u0442\u00a0<strong>\u043f\u043e\u043b\u043d\u044b\u0439 \u0441\u043f\u0435\u043a\u0442\u0440<\/strong>\u00a0\u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043f\u043e\u0434 \u0432\u0441\u0435 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438 REDB: facet search, \u0434\u0435\u0440\u0435\u0432\u043e, \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438, GIN-\u043f\u043e\u043b\u043d\u043e\u0442\u0435\u043a\u0441\u0442, partial-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 NOT NULL, \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0435 CTE \u0434\u043b\u044f \u043f\u0440\u0430\u0432. \u042d\u0442\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u0434\u0432\u0438\u0436\u043a\u0430-\u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438: \u0432\u044b \u043d\u0435 \u0437\u043d\u0430\u0435\u0442\u0435 \u0437\u0430\u0440\u0430\u043d\u0435\u0435, \u043a\u0430\u043a\u043e\u0439 \u043f\u0440\u043e\u0444\u0438\u043b\u044c \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0431\u0443\u0434\u0435\u0442 \u0443 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f.<\/p>\n<p>\u041d\u043e\u00a0<strong>\u0432 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u043c \u0432\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0438 \u0447\u0430\u0441\u0442\u044c \u044d\u0442\u0438\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043c\u043e\u0436\u0435\u0442 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f<\/strong>. \u042d\u0442\u043e \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e. \u041b\u043e\u0433\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 TSUM \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440,\u00a0<code>WhereHasDescendant<\/code>\u00a0(\u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0438 \u0432 \u0435\u0451 \u0434\u043e\u043c\u0435\u043d\u043d\u043e\u0439 \u043c\u043e\u0434\u0435\u043b\u0438 \u043f\u043b\u043e\u0441\u043a\u0438\u0435) \u2014 \u0437\u043d\u0430\u0447\u0438\u0442,\u00a0<code>IX__objects__parent_id_descendant_lookup<\/code>\u00a0\u043b\u0435\u0436\u0438\u0442 \u0432 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u0445 \u0411\u0414, \u043d\u043e \u0447\u0435\u0440\u0435\u0437 \u043d\u0435\u0433\u043e \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0438\u0434\u0443\u0442 \u0441\u043a\u0430\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0432\u044b\u0448\u043b\u043e \u0432 \u043f\u0440\u043e\u0434 \u0438 \u043d\u0430\u0431\u0440\u0430\u043b\u043e 2-4 \u043d\u0435\u0434\u0435\u043b\u0438 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u2014\u00a0<strong>\u0441\u043d\u0438\u043c\u0438\u0442\u0435 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0443 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c<\/strong>\u00a0\u0438 \u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e \u0443\u0431\u0435\u0440\u0438\u0442\u0435 \u043d\u0435\u043d\u0443\u0436\u043d\u043e\u0435:<\/p>\n<pre><code class=\"sql\">SELECT schemaname, relname, indexrelname,       idx_scan,       pg_size_pretty(pg_relation_size(indexrelid)) AS szFROM pg_stat_user_indexesWHERE idx_scan = 0  AND pg_relation_size(indexrelid) &gt; 10*1024*1024  -- \u043f\u043e\u0440\u043e\u0433: \u0442\u043e\u043b\u044c\u043a\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u044b &gt; 10 \u041c\u0411ORDER BY pg_relation_size(indexrelid) DESC;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<figure class=\"full-width \"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/ebf\/ca0\/09a\/ebfca009a4e74546373c20801a80fd3e.png\" alt=\"\u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430 \u043f\u0440\u043e\u0434\u0435\" title=\"\u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430 \u043f\u0440\u043e\u0434\u0435\" width=\"1345\" height=\"1197\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/ebf\/ca0\/09a\/ebfca009a4e74546373c20801a80fd3e.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/ebf\/ca0\/09a\/ebfca009a4e74546373c20801a80fd3e.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<div><figcaption>\u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430 \u043f\u0440\u043e\u0434\u0435<\/figcaption><\/div>\n<\/figure>\n<p>\u041d\u0430 TSUM \u0442\u0430\u043a\u0430\u044f \u0432\u044b\u0431\u043e\u0440\u043a\u0430 \u043f\u043e\u043a\u0430\u0437\u0430\u043b\u0430 \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e ~4423 \u041c\u0411 \u0432 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u0445 \u0441\u00a0<code>idx_scan = 0<\/code>. \u042d\u0442\u043e\u00a0<strong>\u043d\u0435 \u0437\u043d\u0430\u0447\u0438\u0442<\/strong>, \u0447\u0442\u043e \u044d\u0442\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043b\u043e\u0445\u0438\u0435. \u042d\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442 \u2014 \u0432 \u044d\u0442\u043e\u043c \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u043c \u043f\u0440\u043e\u0444\u0438\u043b\u0435 \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u043d\u0430 \u044d\u0442\u0438 \u043f\u0443\u0442\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u043b.<\/p>\n<p>\u0410\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0442\u0430\u043a\u043e\u0439 \u0432\u044b\u0431\u043e\u0440\u043a\u043e\u0439:<\/p>\n<ol>\n<li>\n<p><strong>\u041d\u0435 \u0443\u0434\u0430\u043b\u044f\u0442\u044c \u0441\u0440\u0430\u0437\u0443.<\/strong>\u00a0\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u2014 \u043e\u0431\u0437\u043e\u0440: \u043a\u0430\u043a\u0438\u0435 \u0438\u0437 \u044d\u0442\u0438\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u00ab\u0435\u0449\u0451 \u043d\u0435 \u0441\u0442\u0440\u0435\u043b\u044c\u043d\u0443\u043b\u0438\u00bb (\u043a\u0432\u0430\u0440\u0442\u0430\u043b\u044c\u043d\u0430\u044f \u043e\u0442\u0447\u0451\u0442\u043d\u043e\u0441\u0442\u044c, \u0433\u043e\u0434\u043e\u0432\u044b\u0435 \u0441\u0432\u0435\u0440\u043a\u0438, \u0438\u043c\u043f\u043e\u0440\u0442 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043e\u0431\u044a\u0451\u043c\u0430)? \u0418\u0445 \u0442\u0440\u043e\u0433\u0430\u0442\u044c \u043d\u0435 \u0441\u0442\u043e\u0438\u0442 \u2014 \u043d\u0430 \u0438\u0445 \u043f\u0440\u043e\u0431\u0443\u0436\u0434\u0435\u043d\u0438\u0438 \u0441\u0442\u043e\u0438\u043c\u043e\u0441\u0442\u044c \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0448\u0435, \u0447\u0435\u043c \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u043e\u0442 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f.<\/p>\n<\/li>\n<li>\n<p><strong>\u041e\u0441\u0442\u0430\u0432\u0448\u0438\u0435\u0441\u044f \u2014 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u044b \u043d\u0430\u00a0<\/strong><code><strong>DROP INDEX CONCURRENTLY<\/strong><\/code><strong>.<\/strong>\u00a0\u042d\u0442\u043e \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u0430\u044f \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f: \u0438\u043d\u0434\u0435\u043a\u0441 \u0443\u0434\u0430\u043b\u044f\u0435\u0442\u0441\u044f \u0431\u0435\u0437 \u0431\u043b\u043e\u043a\u0438\u0440\u043e\u0432\u043a\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u0438 \u0435\u0433\u043e \u0432\u0441\u0435\u0433\u0434\u0430 \u043c\u043e\u0436\u043d\u043e \u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0442\u0435\u043c \u0436\u0435\u00a0<code>CREATE INDEX CONCURRENTLY<\/code>\u00a0\u043e\u0431\u0440\u0430\u0442\u043d\u043e \u2014 DDL \u0437\u043d\u0430\u0435\u0442, \u043a\u0430\u043a \u044d\u0442\u043e\u0442 \u0438\u043d\u0434\u0435\u043a\u0441 \u0434\u043e\u043b\u0436\u0435\u043d \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c.<\/p>\n<\/li>\n<li>\n<p><strong>\u041f\u043e\u0441\u043b\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u2014 \u043d\u0430\u0431\u043b\u044e\u0434\u0435\u043d\u0438\u0435 \u0435\u0449\u0451 2-4 \u043d\u0435\u0434\u0435\u043b\u0438.<\/strong>\u00a0\u0415\u0441\u043b\u0438 \u0432 \u043b\u043e\u0433\u0430\u0445 \u043d\u0435 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043d\u0435\u043e\u0436\u0438\u0434\u0430\u043d\u043d\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u044b\u0445 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u0437\u043d\u0430\u0447\u0438\u0442 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0431\u044b\u043b\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u043c. \u0415\u0441\u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u00ab\u043f\u0440\u043e\u0441\u0435\u043b\u043e\u00bb \u2014 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c.<\/p>\n<\/li>\n<\/ol>\n<p>\u042d\u0442\u043e\u00a0<strong>\u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 PostgreSQL<\/strong>, \u043d\u0435 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0430 REDB. \u041d\u043e \u0438\u043c\u0435\u043d\u043d\u043e \u0432 REDB \u043e\u043d\u0430 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0447\u0438\u0449\u0435: \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0437\u0430\u0434\u0438\u0437\u0430\u0439\u043d\u0435\u043d \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0438 \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d \u0432 DDL. \u0412\u044b\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u043b\u0438\u0448\u043d\u0438\u0445 \u2014 \u044d\u0442\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0432 \u043e\u0434\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435, \u0430 \u043d\u0435 \u043e\u0445\u043e\u0442\u0430 \u0437\u0430 \u043d\u0430\u0441\u043b\u043e\u0435\u043d\u0438\u044f\u043c\u0438 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0439 \u0442\u0440\u0451\u0445 \u043b\u0435\u0442 \u0434\u0430\u0432\u043d\u043e\u0441\u0442\u0438 \u043f\u043e \u0431\u0438\u0437\u043d\u0435\u0441-\u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c.<\/p>\n<p>\u0418 \u043e\u0431\u0440\u0430\u0442\u043d\u043e\u0435 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0442\u043e\u0436\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0415\u0441\u043b\u0438 \u0432\u044b \u0432\u0438\u0434\u0438\u0442\u0435, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u043e\u0434\u0438\u043d \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 facet-\u0437\u0430\u043f\u0440\u043e\u0441 \u0433\u043e\u0440\u044f\u0447\u0438\u0439 \u0434\u043e \u0443\u0440\u043e\u0432\u043d\u044f \u00ab\u043d\u0430\u0434\u043e \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0435\u0449\u0451\u00bb \u2014 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0437\u0430\u043f\u0440\u0435\u0449\u0430\u0435\u0442 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c\u00a0<strong>\u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439<\/strong>\u00a0\u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e\u0434 \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u043e\u0442 \u0437\u0430\u043f\u0440\u043e\u0441:<\/p>\n<pre><code class=\"sql\">-- \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \"\u043d\u0430\u0439\u0442\u0438 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u044b \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044f \u0437\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 7 \u0434\u043d\u0435\u0439\"CREATE INDEX IX_my_app__route_by_driverON _values (_id_structure, _ListItem, _id_object)WHERE _id_structure = &lt;id_\u043f\u043e\u043b\u044f_Driver&gt;;<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0422\u0430\u043a\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u2014 \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u0430\u044f \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u044f, \u043e\u043d\u0430 \u043b\u0435\u0436\u0438\u0442 \u0432 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u0432\u0430\u0448\u0435\u0433\u043e \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0430 \u043d\u0435 \u0432 \u044f\u0434\u0440\u0435 REDB. \u0418 \u0441\u043d\u043e\u0432\u0430 \u2014 \u043e\u043d\u0430 \u0442\u043e\u0436\u0435 \u043f\u043e\u0434\u00a0<code>pg_stat_user_indexes<\/code>-\u0430\u0443\u0434\u0438\u0442 \u0447\u0435\u0440\u0435\u0437 2-4 \u043d\u0435\u0434\u0435\u043b\u0438.<\/p>\n<hr\/>\n<h3>\u0427\u0435\u0433\u043e \u043d\u0435\u0442 \u0432 DDL \u0438 \u043f\u043e\u0447\u0435\u043c\u0443<\/h3>\n<p>\u0421\u043a\u0435\u043f\u0442\u0438\u043a \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u0443\u0440\u043e\u0432\u043d\u044f \u0437\u0430\u0434\u0430\u0451\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0432\u043e\u043f\u0440\u043e\u0441: \u00ab\u0410 \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u0442 hash-\u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043d\u0430\u00a0<code><em>String<\/em><\/code><em>? \u041f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u0442 BRIN \u043d\u0430\u00a0<\/em><code>date_create<\/code>? \u041f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u0442 expression-\u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043d\u0430\u00a0<code>LOWER(_String)<\/code>?\u00bb<\/p>\n<p><strong>Hash-\u0438\u043d\u0434\u0435\u043a\u0441\u044b.<\/strong>\u00a0\u0412 Postgres \u0438\u0441\u0442\u043e\u0440\u0438\u0447\u0435\u0441\u043a\u0438 \u0443\u0441\u0442\u0443\u043f\u0430\u044e\u0442 btree \u043f\u043e \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0443 \u043c\u0435\u0442\u0440\u0438\u043a \u0438 \u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442 partial-\u0443\u0441\u043b\u043e\u0432\u0438\u044f. \u0423 \u043d\u0430\u0441 \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b partial \u2014 \u043f\u043e\u044d\u0442\u043e\u043c\u0443 hash \u043d\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043d\u043e, \u0430 \u043d\u0435 \u0438\u0437-\u0437\u0430 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0433\u043e \u0432\u044b\u0431\u043e\u0440\u0430.<\/p>\n<p><strong>BRIN \u043d\u0430\u00a0<\/strong><code><strong><em>date<\/em>create<\/strong><\/code><strong>.<\/strong>\u00a0\u041e\u0431\u043e\u0441\u043d\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442 \u043d\u0430 \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0430\u0440\u0445\u0438\u0432\u043d\u044b\u0445 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445, \u043d\u043e \u0434\u043b\u044f \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u043f\u0440\u043e\u0444\u0438\u043b\u044f REDB \u043e\u043d \u0438\u0437\u0431\u044b\u0442\u043e\u0447\u0435\u043d.\u00a0<code>IX__objects__scheme_date_create (DESC, _id)<\/code>\u00a0\u0443\u0436\u0435 \u0438\u0434\u0451\u0442 \u043f\u043e \u043a\u043e\u043c\u043f\u043e\u0437\u0438\u0442\u043d\u043e\u043c\u0443 \u043a\u043b\u044e\u0447\u0443 \u0438 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u0440\u043e\u0432\u043d\u043e \u0442\u043e\u0442 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0439, \u0440\u0430\u0434\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e BRIN \u0431\u044b\u043b \u0431\u044b \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043e\u0439. BRIN \u0434\u0430\u043b \u0431\u044b \u0432\u044b\u0438\u0433\u0440\u044b\u0448 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 cold-storage \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438 (&gt;10M \u0441\u0442\u0440\u043e\u043a \u043d\u0430 \u043e\u0434\u043d\u0443 \u0441\u0445\u0435\u043c\u0443) \u2014 \u044d\u0442\u043e \u0443\u0436\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0444\u0430\u0437\u0430 \u00ab\u0430\u0440\u0445\u0438\u0432\u043d\u044b\u0435 \u043a\u043b\u0430\u0441\u0441\u044b\u00bb, \u0438 \u0432 DDL \u0442\u0435\u043a\u0443\u0449\u0435\u0433\u043e \u044f\u0434\u0440\u0430 \u043e\u043d\u0430 \u043f\u043e\u043a\u0430 \u043d\u0435 \u0432\u0445\u043e\u0434\u0438\u0442.<\/p>\n<p><strong>Expression-\u0438\u043d\u0434\u0435\u043a\u0441\u044b (<\/strong><code><strong>LOWER(_String)<\/strong><\/code><strong>,\u00a0<\/strong><code><strong><em>DateTimeOffset::date<\/em><\/strong><\/code><strong><em>\u00a0\u0438 \u0442.\u043f.).<\/em><\/strong><em>\u00a0\u0421\u043e\u0437\u043d\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0435 \u0437\u0430\u0448\u0438\u0442\u044b \u0432 DDL. \u042d\u0442\u043e\u00a0<\/em><strong><em>\u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u043e\u0439 \u0432\u044b\u0431\u043e\u0440<\/em><\/strong><em>: case-insensitive \u043f\u043e\u0438\u0441\u043a \u043f\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u043c\u0443 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u043e\u043c\u0443 \u043f\u043e\u043b\u044e, \u0430\u0433\u0440\u0435\u0433\u0430\u0446\u0438\u044f \u043f\u043e \u0434\u043d\u044e\/\u043c\u0435\u0441\u044f\u0446\u0443 \u2014 \u044d\u0442\u043e \u043e\u043f\u0446\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0440\u0435\u0448\u0430\u0442\u044c \u0432 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0430 \u043d\u0435 \u0432 \u044f\u0434\u0440\u0435. GIN \u0441\u00a0<\/em><code><em>pg<\/em>trgm<\/code>\u00a0\u0443\u0436\u0435 \u0434\u0430\u0451\u0442 case-insensitive substring-\u043f\u043e\u0438\u0441\u043a \u0447\u0435\u0440\u0435\u0437 ILIKE \u2014 \u0434\u043b\u044f \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0437\u0430\u0434\u0430\u0447 \u044d\u0442\u043e\u0433\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e.<\/p>\n<p><strong>Bloom, BRIN-multi, GIN \u043d\u0430 jsonb.<\/strong>\u00a0\u0412\u0441\u0435 \u2014 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u044b \u043d\u0430 \u0443\u0437\u043a\u0438\u0435 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438. \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u043e\u0434\u0438\u043d \u043e\u0447\u0435\u043d\u044c \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0437\u0430\u043f\u0440\u043e\u0441, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u043e\u043a\u0430\u0437\u0430\u043d\u043d\u043e \u0433\u043e\u0440\u044f\u0447\u0438\u0439 \u0438 \u0434\u043e\u043a\u0430\u0437\u0430\u043d\u043d\u043e \u043d\u0435 \u043f\u043e\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0435 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e\u0434 \u043d\u0435\u0433\u043e, \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0435\u0439. \u041d\u0435 \u0442\u0440\u043e\u0433\u0430\u044f\u00a0<code>redbPostgre.sql<\/code>.<\/p>\n<p>\u041f\u0440\u0438\u043d\u0446\u0438\u043f \u0437\u0434\u0435\u0441\u044c \u043e\u0431\u0449\u0438\u0439:\u00a0<strong>DDL \u044f\u0434\u0440\u0430 \u043f\u043e\u043a\u0440\u044b\u0432\u0430\u0435\u0442 95% \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0435\u0432, \u043e\u0441\u0442\u0430\u0432\u0448\u0438\u0435\u0441\u044f 5% \u2014 \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u043e\u0439 \u0441\u043b\u043e\u0439<\/strong>. \u042d\u0442\u043e \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u043f\u043e\u043b\u043e\u0436\u043d\u043e EF-\u043f\u043e\u0434\u0445\u043e\u0434\u0443, \u0433\u0434\u0435 DDL \u0441\u0440\u0430\u0437\u0443 \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u0438\u0442 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044e \u0438 \u043b\u044e\u0431\u043e\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u2014 \u0447\u0430\u0441\u0442\u044c \u0435\u0433\u043e \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0439 \u0438\u0441\u0442\u043e\u0440\u0438\u0438.<\/p>\n<hr\/>\n<h3>MSSQL: \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0451 \u0442\u0430\u043a \u0436\u0435<\/h3>\n<p>\u0420\u0430\u0437 \u0443\u0436 \u043f\u043e\u0448\u043b\u0430 \u0440\u0435\u0447\u044c \u043f\u0440\u043e DDL, \u0432\u0430\u0436\u043d\u043e \u0441\u0440\u0430\u0437\u0443 \u0441\u043a\u0430\u0437\u0430\u0442\u044c: \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0435 \u043f\u0440\u043e \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0443 Postgres. \u0424\u0430\u0439\u043b\u00a0<code>redb.MSSql\/sql\/redbMSSQL.sql<\/code>\u00a0\u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0437\u0435\u0440\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432, \u0438 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0439 \u043f\u0440\u0438\u0451\u043c \u00ab\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u044b \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u00bb \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u043e\u0431\u043e\u0438\u0445 \u0434\u0432\u0438\u0436\u043a\u0430\u0445 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e.<\/p>\n<p>\u0427\u0442\u043e \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043e\u0434\u0438\u043d-\u0432-\u043e\u0434\u0438\u043d:<\/p>\n<ul>\n<li>\n<p>\u0412\u0441\u0435 \u0442\u0440\u0438 partial-unique \u043d\u0430\u00a0<code>_values<\/code>\u00a0(\u0432 MSSQL \u2014 filtered indexes \u0441\u00a0<code>WHERE<\/code>, \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441 \u0434\u0440\u0443\u0433\u043e\u0439, \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0430 \u0442\u0430 \u0436\u0435).<\/p>\n<\/li>\n<li>\n<p>Composite-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 facet search (<code>IX__values__structure_object_lookup<\/code>\u00a0\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0432 \u043e\u0431\u043e\u0438\u0445 DDL \u0441 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u0439 \u043a\u043b\u044e\u0447\u0430).<\/p>\n<\/li>\n<li>\n<p>Covering-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0441\u00a0<code>INCLUDE<\/code>\u00a0\u2014 \u043d\u0430\u0442\u0438\u0432\u043d\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u0432 MSSQL \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 2005, \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u044f\u0442\u0441\u044f \u0431\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e.<\/p>\n<\/li>\n<li>\n<p>\u0414\u0435\u0440\u0435\u0432\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 (<code>IX__objects__scheme_parent<\/code>,\u00a0<code>IX__objects__parent_id_descendant_lookup<\/code>) \u2014 \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439.<\/p>\n<\/li>\n<li>\n<p>Partial\/filtered-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434\u00a0<code>RedbPrimitive&lt;T&gt;<\/code>\u00a0\u2014 \u0442\u043e\u0436\u0435 \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439.<\/p>\n<\/li>\n<\/ul>\n<p>\u0427\u0442\u043e \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f:<\/p>\n<ul>\n<li>\n<p><strong>GIN +\u00a0<\/strong><code><strong>pg_trgm<\/strong><\/code>\u00a0\u0434\u043b\u044f substring-\u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e\u00a0<code>_String<\/code>. \u0412 MSSQL \u0430\u043d\u0430\u043b\u043e\u0433 \u2014 full-text search \u0438\u043b\u0438 filtered index \u043f\u043e computed column. \u0412 DDL\u00a0<code>redbMSSQL.sql<\/code>\u00a0\u0438\u0434\u0451\u0442 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 (<code>LIKE<\/code>\u00a0\u043f\u043e \u043e\u0431\u044b\u0447\u043d\u043e\u043c\u0443 btree \u0441 partial-\u0443\u0441\u043b\u043e\u0432\u0438\u0435\u043c \u043d\u0430 \u0434\u043b\u0438\u043d\u0443).<\/p>\n<\/li>\n<li>\n<p><code><strong>NULLS NOT DISTINCT<\/strong><\/code>\u00a0\u0432 Postgres 15+ \u2014 \u0432 MSSQL \u043f\u0438\u0448\u0435\u0442\u0441\u044f \u0438\u043d\u0430\u0447\u0435 (<code>UNIQUE<\/code>\u00a0+ filtered\u00a0<code>WHERE NOT NULL<\/code>).<\/p>\n<\/li>\n<li>\n<p><code><strong>ON DELETE CASCADE<\/strong><\/code><strong>\u00a0\u043e\u0442\u00a0<\/strong><code><strong><em>structures<\/em><\/strong><\/code><strong><em>\u00a0\u043a\u00a0<\/em><\/strong><code><strong>values<\/strong><\/code>\u00a0\u0432 Postgres \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e, \u0432 MSSQL \u043d\u0435\u043b\u044c\u0437\u044f \u0438\u0437-\u0437\u0430 multiple cascade paths \u2014 \u0437\u0430\u043c\u0435\u043d\u0435\u043d\u043e \u043d\u0430\u00a0<code>INSTEAD OF DELETE<\/code>\u00a0\u0442\u0440\u0438\u0433\u0433\u0435\u0440. \u041f\u043b\u0430\u043d DELETE \u0432 MSSQL \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0434\u0440\u0443\u0433\u043e\u0439, \u043d\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0442\u0435 \u0436\u0435.<\/p>\n<\/li>\n<li>\n<p><strong>Per-type filtered \u0438\u043d\u0434\u0435\u043a\u0441\u044b<\/strong>\u00a0\u0432 MSSQL \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u043d\u044b \u0431\u043e\u043b\u0435\u0435 \u044f\u0432\u043d\u043e (<code>IX__values__Long_filter<\/code>,\u00a0<code>IX__values__Guid_filter<\/code>, &#8230;) \u2014 \u0432 Postgres-DDL \u043e\u043d\u0438 \u0437\u0430\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u044b \u043a\u0430\u043a \u00abcovered by composite\u00bb. \u042d\u0442\u043e \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0432 \u0441\u0442\u0440\u0430\u0442\u0435\u0433\u0438\u0438: \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0442\u043e\u0440 MSSQL \u0447\u0443\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0435 \u043b\u044e\u0431\u0438\u0442 \u0443\u0437\u043a\u0438\u0435 filtered-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u0442\u0438\u043f.<\/p>\n<\/li>\n<\/ul>\n<p>\u041d\u043e \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u2014\u00a0<strong>\u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u0430\u044f \u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442\u0441\u044f<\/strong>. \u0422\u0430 \u0436\u0435 \u0440\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0430 2+2+3+\u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430, \u0442\u0430 \u0436\u0435 facet-\u0441\u0445\u0435\u043c\u0430, \u0442\u0430 \u0436\u0435 \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0431\u043e\u0440\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043e\u0442 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u0430\u0441\u0441\u0430. \u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0438\u0448\u0435\u0442 C#-\u043c\u043e\u0434\u0435\u043b\u0438, \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 Postgres \u0438 MSSQL \u043d\u0435 \u0432\u0438\u0434\u043d\u0430 \u0432\u043e\u043e\u0431\u0449\u0435.<\/p>\n<hr\/>\n<h3>TSUM \u043a\u0430\u043a \u043f\u0440\u043e\u0432\u0435\u0440\u043e\u0447\u043d\u044b\u0439 \u043a\u0435\u0439\u0441<\/h3>\n<p>\u0412\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e\u0441\u044c \u043a \u0446\u0438\u0444\u0440\u0430\u043c \u0432 \u043d\u0430\u0447\u0430\u043b\u0435 \u0441\u0442\u0430\u0442\u044c\u0438 \u0438 \u0441\u043e\u0431\u0438\u0440\u0430\u044e \u0438\u0445 \u0432 \u043e\u0434\u043d\u0443 \u0442\u043e\u0447\u043a\u0443.<\/p>\n<p>\u0427\u0442\u043e REDB \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u0432 TSUM:<\/p>\n<ul>\n<li>\n<p>32 \u043a\u043b\u0430\u0441\u0441\u0430 \u0432\u00a0<code>tsum.Domain<\/code>\u00a0(\u043e\u0442\u00a0<code>TransportationRoute<\/code>\u00a0\u0434\u043e\u00a0<code>UserFilterPreference<\/code>),<\/p>\n<\/li>\n<li>\n<p>401 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u0432 \u044d\u0442\u0438\u0445 \u043a\u043b\u0430\u0441\u0441\u0430\u0445 \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u043e,<\/p>\n<\/li>\n<li>\n<p>227 896 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 \u043c\u043e\u043c\u0435\u043d\u0442 \u0441\u043d\u044f\u0442\u0438\u044f \u043c\u0435\u0442\u0440\u0438\u043a,<\/p>\n<\/li>\n<li>\n<p>9 773 174 \u0441\u0442\u0440\u043e\u043a\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0432\u00a0<code>_values<\/code>.<\/p>\n<\/li>\n<\/ul>\n<p>\u0412\u0441\u044f \u044d\u0442\u0430 \u0441\u0445\u0435\u043c\u0430 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u043b\u043e\u0436\u0438\u0442\u0441\u044f \u043d\u0435 \u0432 13 \u0442\u0430\u0431\u043b\u0438\u0446 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u044c, \u0430 \u0432\u00a0<strong>2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0434\u0430\u043d\u043d\u044b\u0445<\/strong>\u00a0(<code>_objects<\/code>\u00a0+\u00a0<code><em>values<\/em><\/code><em>) +\u00a0<\/em><strong><em>2 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u044b\u0445<\/em><\/strong><em>\u00a0(<\/em><code>lists<\/code>\u00a0+\u00a0<code><em>list<\/em>items<\/code>) +\u00a0<strong>3 RTTI<\/strong>\u00a0(<code>_types<\/code>\u00a0+\u00a0<code><em>schemes<\/em><\/code><em>\u00a0+\u00a0<\/em><code>structures<\/code>). \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0448\u0435\u0441\u0442\u044c \u2014 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 (\u043f\u0440\u0430\u0432\u0430, \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438, \u0440\u043e\u043b\u0438, links, dependencies, functions, soft-delete, metadata cache), \u043e\u043d\u0438 \u043d\u0435 \u0437\u0430\u0432\u0438\u0441\u044f\u0442 \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0431\u0438\u0437\u043d\u0435\u0441-\u043a\u043b\u0430\u0441\u0441\u043e\u0432. \u041f\u043e\u043b\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u2014 \u0442\u043e\u0442 \u0436\u0435\u00a0<code>redbPostgre.sql<\/code>, \u0447\u0442\u043e \u0438 \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0441 \u043f\u044f\u0442\u044c\u044e \u043a\u043b\u0430\u0441\u0441\u0430\u043c\u0438. \u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 EF-\u0440\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0435 \u044d\u0442\u0438\u0445 32 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0441 \u0438\u0445 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0430\u043c\u0438 \u0438 snapshot&#8217;\u0430\u043c\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0431\u044b\u00a0<strong>\u043f\u043e\u0440\u044f\u0434\u043a\u0430 60-80 \u0442\u0430\u0431\u043b\u0438\u0446<\/strong>\u00a0\u0438\u00a0<strong>200+ \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432<\/strong>\u00a0\u2014 \u0441 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0439 \u0438\u0441\u0442\u043e\u0440\u0438\u0435\u0439 \u0437\u0430 \u0432\u0441\u0451 \u0432\u0440\u0435\u043c\u044f \u0436\u0438\u0437\u043d\u0438 \u043f\u0440\u043e\u0435\u043a\u0442\u0430.<\/p>\n<p>\u041f\u0440\u043e\u0434-\u043c\u0435\u0442\u0440\u0438\u043a\u0438 \u0442\u0438\u043f\u043e\u0432\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043a\u0430\u0437\u043e\u0432:<\/p>\n<ul>\n<li>\n<p><strong>999 \u0437\u0430\u043a\u0430\u0437\u043e\u0432 \u0432 \u043e\u0434\u043d\u043e\u0439 XML-\u043f\u0430\u0447\u043a\u0435 \u0438\u0437 SAP<\/strong>, \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u2014\u00a0<strong>991 \u043c\u0441<\/strong>\u00a0total:<\/p>\n<ul>\n<li>\n<p><code>sync = 482 \u043c\u0441<\/code>\u00a0\u2014 \u0441\u0432\u0435\u0440\u043a\u0430 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u043e\u0432 (Drivers, Vehicles, ShippingPoints, BusinessTypes, DeliveryStatuses) \u0441 REDB-\u0441\u043f\u0438\u0441\u043a\u0430\u043c\u0438,<\/p>\n<\/li>\n<li>\n<p><code>query = 139 \u043c\u0441<\/code>\u00a0\u2014\u00a0<strong>\u043e\u0434\u0438\u043d<\/strong>\u00a0SELECT, \u0437\u0430\u0433\u0440\u0443\u0437\u0438\u043b \u0432\u0441\u0435 999 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u043e\u0432 \u043f\u043e \u0438\u0445 \u043a\u043e\u0434\u0430\u043c,<\/p>\n<\/li>\n<li>\n<p><code>save = 154 \u043c\u0441<\/code>\u00a0\u2014\u00a0<code>SaveAsync<\/code>\u00a0\u0434\u043b\u044f\u00a0<strong>32 \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445<\/strong>\u00a0\u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 (2 created + 30 updated). \u041e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 967 \u043f\u0440\u043e\u043f\u0443\u0449\u0435\u043d\u044b \u0447\u0435\u0440\u0435\u0437\u00a0<code>ComputeHash()<\/code>\u00a0\u2014 \u043d\u0435 \u0434\u043e\u0448\u043b\u0438 \u0434\u043e \u0411\u0414 \u0432\u043e\u043e\u0431\u0449\u0435.<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u0418\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u2014\u00a0<strong>2 \u044f\u0434\u0440\u0430<\/strong>,\u00a0<strong>default-\u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 PostgreSQL<\/strong>\u00a0(\u0431\u0435\u0437 \u0442\u044e\u043d\u0438\u043d\u0433\u0430\u00a0<code>shared_buffers<\/code>, \u0431\u0435\u0437\u00a0<code>pg_prewarm<\/code>, \u0431\u0435\u0437 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u043d\u043e\u0433\u043e\u00a0<code>work_mem<\/code>).<\/p>\n<\/li>\n<li>\n<p>\u041a\u044d\u0448\u0430 \u0443\u0440\u043e\u0432\u043d\u044f REDB-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430 \u043d\u0435\u0442 \u2014 \u043a\u0430\u0436\u0434\u044b\u0439\u00a0<code>Query&lt;T&gt;()<\/code>\u00a0\u0438\u0434\u0451\u0442 \u0432 \u0411\u0414.<\/p>\n<\/li>\n<\/ul>\n<p>\u042d\u0442\u043e \u043d\u0435 \u00ab\u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0434\u043e\u0431\u0440\u0430\u043d\u043d\u044b\u0439 \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u00bb \u2014 \u044d\u0442\u043e \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0439 production-\u0446\u0438\u043a\u043b, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u043e\u0431\u044b\u0447\u043d\u044b\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043f\u0438\u0448\u0435\u0442 \u043e\u0431\u044b\u0447\u043d\u044b\u0435 C#-\u043c\u043e\u0434\u0435\u043b\u0438 \u0447\u0435\u0440\u0435\u0437\u00a0<code>[RedbScheme]<\/code>\u00a0\u0430\u0442\u0440\u0438\u0431\u0443\u0442, \u0438 \u043b\u043e\u0433\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043f\u0440\u043e\u0441\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. Bulk \u043d\u0430 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0435 (\u043e\u0434\u0438\u043d SELECT \u043d\u0430 999 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432), bulk \u043d\u0430 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 (<code>_objects<\/code>\u00a0\u0438\u00a0<code>_values<\/code>\u00a0\u2014 \u043e\u0431\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043e\u0434\u043d\u043e\u0439 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0435\u0439 \u0447\u0435\u0440\u0435\u0437 COPY protocol), \u0440\u0430\u043d\u043d\u0438\u0439 skip \u0442\u0430\u043c, \u0433\u0434\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c.<\/p>\n<p>\u0413\u043b\u0430\u0432\u043d\u044b\u0439 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0432\u044b\u0432\u043e\u0434:\u00a0<strong>REDB \u0443\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u044d\u0442\u0438 \u0446\u0438\u0444\u0440\u044b \u043d\u0435 \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0447\u0443\u0434\u0435\u0441\u043d\u043e\u043c\u0443 \u0441\u0442\u0435\u0447\u0435\u043d\u0438\u044e \u043e\u0431\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u0441\u0442\u0432, \u0430 \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0434\u0432\u0438\u0436\u043e\u043a \u043d\u0435 \u0434\u0435\u043b\u0430\u0435\u0442 \u043b\u0438\u0448\u043d\u0435\u0433\u043e<\/strong>. \u0418\u043d\u0434\u0435\u043a\u0441\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u043b\u0430\u043d \u0437\u0430\u0448\u0438\u0442 \u0432 \u0441\u0445\u0435\u043c\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f; bulk \u0442\u0430\u043c, \u0433\u0434\u0435 \u043c\u043e\u0436\u043d\u043e bulk; change tracking \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u0442 \u0441\u0430\u043c\u043e\u0435 \u0434\u043e\u0440\u043e\u0433\u043e\u0435 \u2014 DML-\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u043d\u0430 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043d\u0435 \u0431\u044b\u043b\u043e.<\/p>\n<hr\/>\n<h3>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0438 \u0434\u0430\u043b\u044c\u0448\u0435 \u043f\u043e \u0446\u0438\u043a\u043b\u0443<\/h3>\n<p>\u0418\u0442\u043e\u0433 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0439. \u0423 REDB\u00a0<strong>\u043e\u0434\u0438\u043d<\/strong>\u00a0\u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0432 DDL \u2014 \u043e\u043a\u043e\u043b\u043e 50 \u0448\u0442\u0443\u043a \u043d\u0430 \u0432\u0441\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443. \u042d\u0442\u043e\u0442 \u043d\u0430\u0431\u043e\u0440 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u043b\u044e\u0431\u0443\u044e \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0445\u0435\u043c\u0443: 32 \u043a\u043b\u0430\u0441\u0441\u0430, 100 \u043a\u043b\u0430\u0441\u0441\u043e\u0432, 500 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u2014 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0442\u0430 \u0436\u0435. \u042d\u0442\u043e \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u043f\u043e\u043b\u043e\u0436\u043d\u043e EF-\u043f\u043e\u0434\u0445\u043e\u0434\u0443, \u0433\u0434\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043b\u043e\u0434\u044f\u0442\u0441\u044f \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 \u0438 \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u044e\u0442\u0441\u044f \u0432 \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0434\u043e\u043b\u0433, \u0442\u0440\u0435\u0431\u0443\u044e\u0449\u0438\u0439 \u0440\u0435\u0433\u0443\u043b\u044f\u0440\u043d\u043e\u0439 \u0447\u0438\u0441\u0442\u043a\u0438.<\/p>\n<p>\u042d\u043a\u0441\u043f\u043b\u0443\u0430\u0442\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u0430\u0442\u0442\u0435\u0440\u043d \u2014 \u043f\u043e\u0441\u043b\u0435 \u0441\u0442\u0430\u0431\u0438\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0441\u043d\u0438\u043c\u0438\u0442\u0435\u00a0<code>pg_stat_user_indexes<\/code>, \u0443\u0432\u0438\u0434\u0438\u0442\u0435 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442\u043e\u0432 \u0441\u00a0<code>idx_scan = 0<\/code>, \u0438 \u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e (\u0447\u0435\u0440\u0435\u0437\u00a0<code>DROP INDEX CONCURRENTLY<\/code>\u00a0\u0441 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u043e\u0442\u043a\u0430\u0442\u0430) \u0443\u0431\u0435\u0440\u0438\u0442\u0435 \u043b\u0438\u0448\u043d\u0435\u0435. \u041f\u0440\u0438\u0431\u0430\u0432\u0438\u0442\u0435 \u0441\u0432\u043e\u0438 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u0433\u043e\u0440\u044f\u0447\u0438\u0435 \u043f\u0440\u0438\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0435\u0439, \u043d\u0435 \u0442\u0440\u043e\u0433\u0430\u044f \u044f\u0434\u0440\u043e.<\/p>\n<p>\u0412 MSSQL \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0451 \u0442\u0430\u043a \u0436\u0435. \u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0442\u043b\u0438\u0447\u0438\u044f \u2014 \u0432 \u0441\u043f\u043e\u0441\u043e\u0431\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u0446\u0438\u0438 \u0442\u0435\u043a\u0441\u0442\u0430 \u0438 \u0432 filtered-\u0438\u043d\u0434\u0435\u043a\u0441\u0430\u0445 per-type, \u043d\u043e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u0430\u044f \u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442\u0441\u044f.<\/p>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u043f\u043e \u0446\u0438\u043a\u043b\u0443:<\/p>\n<ul>\n<li>\n<p><strong>\u0421\u0442\u0430\u0442\u044c\u044f 2<\/strong>\u00a0\u2014 Code-first \u0441\u0445\u0435\u043c\u044b: \u043a\u0430\u043a\u00a0<code>SyncSchemeAsync&lt;T&gt;<\/code>\u00a0\u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u0443\u0435\u0442 C#-\u043a\u043b\u0430\u0441\u0441 \u0432 \u0441\u0442\u0440\u043e\u043a\u0438\u00a0<code><em>schemes<\/em><\/code><em>\u00a0+\u00a0<\/em><code>structures<\/code>, \u0447\u0442\u043e \u0442\u0430\u043a\u043e\u0435\u00a0<code><em>structure<\/em>hash<\/code>, \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043e\u043d\u0431\u043e\u0440\u0434\u0438\u043d\u0433 \u043f\u0440\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0438 \u043d\u043e\u0432\u043e\u0433\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430.<\/p>\n<\/li>\n<li>\n<p><strong>\u0421\u0442\u0430\u0442\u044c\u044f 3<\/strong>\u00a0\u2014 CRUD:\u00a0<code>SaveAsync<\/code>\u00a0\u0438\u00a0<code>LoadAsync<\/code>\u00a0\u0438\u0437\u043d\u0443\u0442\u0440\u0438: change tracking \u0447\u0435\u0440\u0435\u0437 TreeDiff, bulk insert \u0447\u0435\u0440\u0435\u0437 COPY protocol, lazy loading.<\/p>\n<\/li>\n<li>\n<p><strong>\u0421\u0442\u0430\u0442\u044c\u044f 4<\/strong>\u00a0\u2014 LINQ-\u0437\u0430\u043f\u0440\u043e\u0441\u044b: \u043a\u0430\u043a\u00a0<code>Where(x =&gt; x.Salary &gt; 80000)<\/code>\u00a0\u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u0435\u0442\u0441\u044f \u0432 SQL \u0441\u00a0<code>CASE WHEN <em>id<\/em>structure = X THEN _Long END &gt; 80000<\/code>, \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442\u00a0<code>OrderBy<\/code>\u00a0\u0438 \u043e\u043a\u043e\u043d\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438.<\/p>\n<\/li>\n<li>\n<p><strong>\u0421\u0442\u0430\u0442\u044c\u044f 5<\/strong>\u00a0\u2014 \u0414\u0435\u0440\u0435\u0432\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432:\u00a0<code>LoadTreeAsync<\/code>,\u00a0<code>GetDescendantsAsync<\/code>,\u00a0<code>WhereHasAncestor<\/code>, \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0435 CTE.<\/p>\n<\/li>\n<li>\n<p><strong>\u0421\u0442\u0430\u0442\u044c\u044f 6<\/strong>\u00a0\u2014 \u041e\u043a\u043e\u043d\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438:\u00a0<code>Win.RowNumber()<\/code>,\u00a0<code>Win.Rank()<\/code>,\u00a0<code>PartitionBy\/OrderBy<\/code>\u00a0\u043f\u043e\u0432\u0435\u0440\u0445 REDB-\u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432.<\/p>\n<\/li>\n<\/ul>\n<p>\u0413\u043b\u0443\u0431\u043e\u043a\u043e\u0435 \u043f\u043e\u0433\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0432 C# \u2014 \u044d\u0442\u043e \u0441\u0442\u0430\u0442\u044c\u0438 3-5 \u0446\u0438\u043a\u043b\u0430. \u0417\u0434\u0435\u0441\u044c, \u0432 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0447\u0430\u0441\u0442\u0438, \u043e\u0441\u0442\u0430\u043b\u0441\u044f \u043e\u0434\u0438\u043d \u0441\u044e\u0436\u0435\u0442 \u2014 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u0441\u0445\u0435\u043c, \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u0441 \u043d\u0435\u0433\u043e \u043d\u0430\u0447\u043d\u0451\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0430\u044f \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u044f.<\/p>\n<hr\/>\n<h3>\u0421\u0441\u044b\u043b\u043a\u0438<\/h3>\n<ul>\n<li>\n<p><a href=\"https:\/\/github.com\/redbase-app\" rel=\"noopener noreferrer nofollow\">GitHub redbase-app<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/redbase-app\/redb\" rel=\"noopener noreferrer nofollow\">\u0420\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439 redb.Core<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/redbase-app\/redb\/blob\/main\/redb.Postgres\/sql\/redbPostgre.sql\" rel=\"noopener noreferrer nofollow\">\u0421\u0445\u0435\u043c\u0430 Postgres (redbPostgre.sql)<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/redbase-app\/redb\/blob\/main\/redb.MSSql\/sql\/redbMSSQL.sql\" rel=\"noopener noreferrer nofollow\">\u0421\u0445\u0435\u043c\u0430 MS SQL (redbMSSQL.sql)<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/redbase.app\/\" rel=\"noopener noreferrer nofollow\">\u0414\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f \u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u044b (EN)<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/redb.ru\/\" rel=\"noopener noreferrer nofollow\">\u0414\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f (RU)<\/a><\/p>\n<\/li>\n<\/ul>\n<hr\/>\n<h3>\u041f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0435 \u0441\u0442\u0430\u0442\u044c\u0438 \u0441\u0435\u0440\u0438\u0438 (\u043d\u0430 \u0425\u0430\u0431\u0440\u0435)<\/h3>\n<ul>\n<li>\n<p><a href=\"https:\/\/habr.com\/ru\/articles\/1042058\/\" rel=\"noopener noreferrer nofollow\">\u0427\u0442\u043e \u044f \u0441\u0442\u0440\u043e\u0438\u043b \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 6 \u043b\u0435\u0442: REDB \u2014 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0434\u0432\u0438\u0436\u043e\u043a \u0434\u0430\u043d\u043d\u044b\u0445<\/a>\u00a0\u2014 \u043e\u0431\u0437\u043e\u0440\u043d\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f: LINQ, \u0434\u0435\u0440\u0435\u0432\u044c\u044f, redb.Route, redb.Tsak.<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/habr.com\/ru\/articles\/%3CTODO_PART1_ID%3E\/\" rel=\"noopener noreferrer nofollow\">REDB \u0438\u0437\u043d\u0443\u0442\u0440\u0438, \u0441\u0442\u0430\u0442\u044c\u044f 1: 13 \u0442\u0430\u0431\u043b\u0438\u0446, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432\u0441\u0451<\/a>\u00a0\u2014 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0411\u0414, RTTI vs EAV,\u00a0<code><em>values<\/em><\/code><em>\u00a0\u0438 \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438,\u00a0<\/em><code>scheme_metadata_cache<\/code>.<\/p>\n<\/li>\n<li>\n<p>redb.Route 3.0 \/ 3.0.1 \/ 3.1.0 \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u0446\u0438\u043a\u043b \u043f\u043e ESB-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0443 \u043f\u043e\u0432\u0435\u0440\u0445 redb.<\/p>\n<\/li>\n<\/ul>\n<\/div>\n<p>\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1045208\/\">https:\/\/habr.com\/ru\/articles\/1045208\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>redb indexREDB \u0438\u0437\u043d\u0443\u0442\u0440\u0438, \u0441\u0442\u0430\u0442\u044c\u044f 1.1: \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0438\u043b\u0438 \u043f\u043e\u0447\u0435\u043c\u0443 3 \u0442\u0430\u0431\u043b\u0438\u0446 \u043d\u0430 \u043b\u044e\u0431\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u2014 \u044d\u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e\u0412\u00a0\u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0447\u0430\u0441\u0442\u0438 \u0446\u0438\u043a\u043b\u0430\u00a0\u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438 13 \u0442\u0430\u0431\u043b\u0438\u0446 REDB: \u043a\u0430\u043a \u0443\u0441\u0442\u0440\u043e\u0435\u043d\u044b\u00a0objects,\u00a0values,\u00a0structures, \u043a\u0430\u043a RTTI-\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 \u0441\u0442\u0430\u0440\u043e\u0433\u043e EAV-\u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430, \u0437\u0430\u0447\u0435\u043c \u043d\u0443\u0436\u0435\u043d\u00a0scheme_metadata_cache. \u0415\u0441\u043b\u0438 \u043d\u0435 \u0447\u0438\u0442\u0430\u043b\u0438 \u2014 \u043d\u0430\u0447\u043d\u0438\u0442\u0435 \u0441 \u043d\u0435\u0451, \u0431\u0435\u0437 \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0441\u0445\u0435\u043c\u044b \u0434\u0430\u043b\u044c\u0448\u0435 \u0442\u044f\u0436\u0435\u043b\u043e.\u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u2014 \u0442\u043e, \u0447\u0442\u043e \u043e\u0431\u044b\u0447\u043d\u043e \u0438\u0434\u0451\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u043e\u043c:\u00a0\u00ab\u0410 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0433\u0434\u0435? \u0423 \u0432\u0430\u0441 \u0436\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432\u0441\u0435\u0445 \u043f\u043e\u043b\u0435\u0439 \u043b\u0435\u0436\u0430\u0442 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435. \u041b\u044e\u0431\u043e\u0439 WHERE \u2014 \u044d\u0442\u043e Seq Scan \u043f\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430\u043c \u0441\u0442\u0440\u043e\u043a\u00bb.\u042d\u0442\u043e \u0441\u0442\u0430\u0442\u044c\u044f 1.1, \u0430 \u043d\u0435 2 \u2014 \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u043d\u0430 \u043f\u0440\u044f\u043c\u043e\u0435 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u0430 \u043f\u0440\u043e \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435.\u00a0\u0413\u043b\u0443\u0431\u043e\u043a\u043e\u0435 \u043f\u043e\u0433\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0432 C# \u2014 \u044d\u0442\u043e \u0441\u0442\u0430\u0442\u044c\u0438 3-5 \u0446\u0438\u043a\u043b\u0430: Code-first \u0441\u0445\u0435\u043c\u044b (SyncSchemeAsync&lt;T&gt;), CRUD (SaveAsync\/LoadAsync), LINQ-\u0442\u0440\u0430\u043d\u0441\u043b\u044f\u0442\u043e\u0440. \u0417\u0434\u0435\u0441\u044c \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u0432 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u0411\u0414 \u0438 DDL.\u0426\u0438\u0444\u0440\u044b, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u043f\u0438\u0440\u0430\u0435\u043c\u0441\u044f, \u2014 \u0441 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0434\u0430: TSUM, \u043b\u043e\u0433\u0438\u0441\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430, \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u0435 \u0433\u0440\u0443\u0437\u043e\u0432\u0438\u043a\u043e\u0432 \u0438 \u0437\u0430\u043a\u0430\u0437\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0420\u0426.TL;DR:\u00a0\u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 EF-\u0441\u0445\u0435\u043c\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043b\u043e\u0434\u044f\u0442\u0441\u044f \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438. \u0412 REDB \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0437\u0430\u0434\u0438\u0437\u0430\u0439\u043d\u0435\u043d \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0432 DDL \u0438 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u043b\u044e\u0431\u0443\u044e \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0445\u0435\u043c\u0443 \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 33-\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043d\u0438 \u043e\u0434\u043d\u043e\u0439 \u043d\u043e\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u0432\u00a0redbPostgre.sql. \u0410\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u0434 \u0431\u0438\u0437\u043d\u0435\u0441-\u0434\u0430\u043d\u043d\u044b\u0435 \u043b\u044e\u0431\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u2014 \u0432\u0441\u0435\u0433\u043e\u00a02 \u0442\u0430\u0431\u043b\u0438\u0446\u044b\u00a0(_objects\u00a0+\u00a0_values), \u043f\u043b\u044e\u0441\u00a02\u00a0\u043f\u043e\u0434 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438 \u0438\u00a03\u00a0\u043f\u043e\u0434 RTTI; \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u2014 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430, \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u043d\u0430\u044f \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432. \u041d\u0430 \u043f\u0440\u043e\u0434\u0435 TSUM \u044d\u0442\u043e \u0434\u0430\u0451\u0442\u00a0999 \u0437\u0430\u043a\u0430\u0437\u043e\u0432 \/ 991 \u043c\u0441\u00a0\u043d\u0430 2 \u044f\u0434\u0440\u0430\u0445 \u0431\u0435\u0437 \u0442\u044e\u043d\u0438\u043d\u0433\u0430 PG \u0438 \u0431\u0435\u0437 \u043a\u044d\u0448\u0430 \u0443\u0440\u043e\u0432\u043d\u044f \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430: \u043e\u0434\u0438\u043d SELECT \u043d\u0430 999 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u043e\u0432 (139 \u043c\u0441), bulk-save 32 \u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u0447\u0435\u0440\u0435\u0437 COPY (154 \u043c\u0441), 967 \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0445 \u043e\u0442\u0441\u0435\u0447\u0435\u043d\u044b \u0434\u043e \u0411\u0414 \u0447\u0435\u0440\u0435\u0437\u00a0ComputeHash().\u0412\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0441\u043a\u0435\u043f\u0442\u0438\u043a\u0430\u0412\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e \u043f\u0440\u0438\u043b\u0435\u0442\u0430\u0435\u0442 \u043f\u043e\u0441\u043b\u0435 \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u0438 \u0441\u0442\u0430\u0442\u044c\u0438 1, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a:\u00ab\u041e\u043a\u0435\u0439, \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 \u043b\u0443\u0447\u0448\u0435, \u0447\u0435\u043c \u0441\u0442\u0440\u043e\u043a\u043e\u0432\u044b\u0439 EAV. \u041d\u043e \u0443 \u0432\u0430\u0441 \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e 9.7 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430 \u0441\u0442\u0440\u043e\u043a \u0432\u00a0_values. \u041b\u044e\u0431\u043e\u0439 \u043e\u0441\u043c\u044b\u0441\u043b\u0435\u043d\u043d\u044b\u0439 \u0437\u0430\u043f\u0440\u043e\u0441 \u2014\u00a0WHERE Salary &gt; 80000\u00a0\u0438\u043b\u0438\u00a0WHERE OrderDate &gt;= &#8216;2026-06-01&#8217;\u00a0\u2014 \u044d\u0442\u043e \u043f\u043e\u0438\u0441\u043a \u0438\u0433\u043e\u043b\u043a\u0438 \u0432 \u0441\u0442\u043e\u0433\u0435. \u0411\u0435\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0435 \u043f\u043e\u043b\u0435 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0445\u0435\u043c\u044b \u0432\u044b \u0431\u0443\u0434\u0435\u0442\u0435 \u0436\u0438\u0442\u044c \u0432 Seq Scan\u00bb.\u0412\u043e\u0437\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0440\u0430\u0441\u0442\u0451\u0442 \u0438\u0437 \u0430\u0441\u0441\u043e\u0446\u0438\u0430\u0446\u0438\u0438 \u0441\u043e \u0441\u0442\u0430\u0440\u044b\u043c\u0438 EAV-\u0441\u0445\u0435\u043c\u0430\u043c\u0438 \u0432\u0438\u0434\u0430\u00a0attribute_name TEXT, value TEXT\u00a0\u2014 \u0442\u0430\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e\u00a0value\u00a0\u0431\u0435\u0441\u043f\u043e\u043b\u0435\u0437\u0435\u043d, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0440\u0430\u0437\u043d\u043e\u0442\u0438\u043f\u043d\u044b\u0435, \u0442\u0440\u0435\u0431\u0443\u044e\u0442 cast \u043d\u0430 \u043b\u0435\u0442\u0443, \u0438 \u0441\u0435\u043b\u0435\u043a\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u00a0attribute_name\u00a0\u043d\u0438\u0437\u043a\u0430\u044f.REDB \u0443\u0441\u0442\u0440\u043e\u0435\u043d \u0438\u043d\u0430\u0447\u0435 \u043d\u0430 \u0434\u0432\u0443\u0445 \u0443\u0440\u043e\u0432\u043d\u044f\u0445. \u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0443\u0436\u0435 \u0440\u0430\u0437\u043b\u043e\u0436\u0435\u043d\u044b \u043f\u043e \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u043a\u043e\u043b\u043e\u043d\u043a\u0430\u043c (_Long,\u00a0String,\u00a0Numeric,\u00a0DateTimeOffset&#8230;) \u2014 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e cast. \u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u0443 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438\u00a0values\u00a0\u0435\u0441\u0442\u044c\u00a0idstructure\u00a0\u2014 bigint-\u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 \u043f\u043e\u043b\u044f \u0441\u0445\u0435\u043c\u044b. \u041d\u0430 401 \u043f\u043e\u043b\u0435 \u0432 TSUM \u044d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u00a0WHERE idstructure = X\u00a0\u0441\u0440\u0430\u0437\u0443 \u043e\u0442\u0441\u0435\u043a\u0430\u0435\u0442 ~99.75% \u0441\u0442\u0440\u043e\u043a \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0435\u0449\u0451 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435.\u041d\u043e \u044d\u0442\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u0435\u043d\u0438\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0435. \u0412\u043e\u043f\u0440\u043e\u0441 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439:\u00a0\u043a\u0430\u043a \u0438\u043c\u0435\u043d\u043d\u043e \u0437\u0430\u0448\u0438\u0442\u044b \u0438\u043d\u0434\u0435\u043a\u0441\u044b, \u0447\u0442\u043e\u0431\u044b facet-\u0437\u0430\u043f\u0440\u043e\u0441 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043b \u0437\u0430 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434\u044b \u043d\u0430 9.7M \u0441\u0442\u0440\u043e\u043a?\u00a0\u0420\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043f\u043e \u0448\u0430\u0433\u0430\u043c.\u0413\u043b\u0430\u0432\u043d\u043e\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0435 \u043d\u0430\u0431\u043b\u044e\u0434\u0435\u043d\u0438\u0435: \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u044b \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u043b\u043e\u0433\u0438 (\u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438\u0437 &gt;9m \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432\u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 EF-\u0440\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0442\u0430\u0431\u043b\u0438\u0446 \u0440\u0430\u0441\u0442\u0451\u0442 \u043b\u0438\u043d\u0435\u0439\u043d\u043e \u0441 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. \u041d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0432 \u0441\u0440\u0435\u0434\u043d\u0435\u043c 3-5 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432: PK, \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430 FK, \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u0431\u0438\u0437\u043d\u0435\u0441-\u0444\u0438\u043b\u044c\u0442\u0440\u044b. \u041f\u043e\u044d\u0442\u043e\u043c\u0443\u00a0\u043e\u0431\u0449\u0435\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0432 \u0411\u0414 \u0440\u0430\u0441\u0442\u0451\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u043f\u043b\u0438\u043a\u0430\u0442\u0438\u0432\u043d\u043e\u00a0\u0441 \u0440\u043e\u0441\u0442\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0430.\u0412\u043e\u0437\u044c\u043c\u0451\u043c TSUM \u043a\u0430\u043a \u043f\u0440\u0438\u043c\u0435\u0440. \u0412\u043e\u0442 \u0447\u0442\u043e \u043b\u0435\u0436\u0438\u0442 \u0432\u00a0tsum.Domain\/Entities:TransportationRoute\u00a0(\u043c\u0430\u0440\u0448\u0440\u0443\u0442 \u043f\u0435\u0440\u0435\u0432\u043e\u0437\u043a\u0438)TransportationPoint\u00a0(\u0442\u043e\u0447\u043a\u0430 \u043c\u0430\u0440\u0448\u0440\u0443\u0442\u0430)Driver,\u00a0Vehicle,\u00a0ShippingPoint,\u00a0YardPlaceSliceSettings,\u00a0SliceSnapshot,\u00a0TransportSnapshot,\u00a0TransportNormSpecialRcSettings,\u00a0TonnageGroupSettings,\u00a0GarageStateTsumAdUserRef,\u00a0UserFilterPreference15 \u00ab\u043a\u043e\u0440\u043d\u0435\u0432\u044b\u0445\u00bb \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439. \u041d\u043e \u044d\u0442\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430\u0447\u0430\u043b\u043e. \u0422\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u0434\u043d\u043e\u043c\u00a0TransportationRoute\u00a0\u043c\u044b \u0432\u0438\u0434\u0438\u043c \u0441\u0441\u044b\u043b\u043a\u0438 \u043d\u0430 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438:\u00a0Drivers,\u00a0Vehicles,\u00a0CarMarks,\u00a0ShippingPoints,\u00a0BusinessTypes,\u00a0YardPlaces\u00a0(\u00d72 \u2014\u00a0PlaceTo\u00a0\/\u00a0PlaceFrom),\u00a0LoadingZones,\u00a0TransportStatuses,\u00a0DeliveryStatuses,\u00a0TripRisks. \u0418 \u0432 \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437 \u0434\u0440\u0443\u0433\u0438\u0445 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u2014 \u0441\u0432\u043e\u0439 \u043d\u0430\u0431\u043e\u0440 \u043b\u0443\u043a\u0430\u043f\u043e\u0432: \u0442\u0438\u043f\u044b \u043a\u0443\u0437\u043e\u0432\u0430, \u0441\u0442\u0430\u0442\u0443\u0441\u044b \u0433\u043e\u0442\u043e\u0432\u043d\u043e\u0441\u0442\u0438, \u043f\u0440\u0438\u0447\u0438\u043d\u044b \u0437\u0430\u0434\u0435\u0440\u0436\u0435\u043a, \u043a\u043b\u0430\u0441\u0441\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b \u0440\u0435\u0439\u0441\u043e\u0432.\u0412 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0441\u0445\u0435\u043c\u0435 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0430\u043a\u043e\u0439 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a \u2014 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u0430:\u00a0Drivers,\u00a0Vehicles,\u00a0CarMarks, &#8230;, \u043f\u043b\u044e\u0441 audit\/history-\u0442\u0430\u0431\u043b\u0438\u0446\u044b (TransportSnapshot,\u00a0SliceSnapshot\u00a0\u2014 \u044d\u0442\u043e \u044f\u0432\u043d\u043e snapshot-\u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438), \u043f\u043b\u044e\u0441 M2M-\u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0434\u043b\u044f \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u043e\u043d\u043d\u044b\u0445 \u0441\u0432\u044f\u0437\u0435\u0439.\u00a0\u0420\u0435\u0430\u043b\u0438\u0441\u0442\u0438\u0447\u043d\u0430\u044f \u043e\u0446\u0435\u043d\u043a\u0430 \u0434\u043b\u044f TSUM \u0432 \u043a\u043b\u0430\u0441\u0441\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0440\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0435 \u2014 60-80 \u0442\u0430\u0431\u043b\u0438\u0446.\u0421 60-80 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u043c\u0438 \u0438 \u0441\u0440\u0435\u0434\u043d\u0438\u043c\u0438 3-4 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u2014\u00a0\u043c\u0435\u0436\u0434\u0443 200 \u0438 320 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c, \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c, \u043f\u0435\u0440\u0435\u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c, \u0434\u0440\u043e\u043f\u0430\u0442\u044c \u043a\u043e\u0433\u0434\u0430 \u0443\u0441\u0442\u0430\u0440\u0435\u043b\u043e. \u041a\u0430\u0436\u0434\u044b\u0439 \u0440\u0435\u043b\u0438\u0437 \u0432 EF-\u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044e \u0432\u0438\u0434\u0430\u00a0AddColumn\u00a0+\u00a0CreateIndex. \u041d\u0430 \u0432\u0442\u043e\u0440\u043e\u0439 \u0433\u043e\u0434 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 DBA \u0438\u043b\u0438 \u0441\u0442\u0430\u0440\u0448\u0438\u0439 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043e\u0431\u0445\u043e\u0434\u0438\u0442 \u0441\u0445\u0435\u043c\u0443 \u0441 \u0444\u043e\u043d\u0430\u0440\u0438\u043a\u043e\u043c \u0438 \u0443\u0434\u0430\u043b\u044f\u0435\u0442 \u0434\u0443\u0431\u043b\u0438 (\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u043a\u043e\u043f\u0438\u043b\u0438\u0441\u044c \u0438\u0437-\u0437\u0430 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0440\u0430\u0437\u043d\u044b\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043d\u0430\u043a\u0430\u0442\u0438\u043b\u0438 \u043f\u043e\u0445\u043e\u0436\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043f\u043e\u0434 \u0447\u0443\u0442\u044c \u0440\u0430\u0437\u043d\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b).\u0412 REDB \u044d\u0442\u043e\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043f\u043e-\u0434\u0440\u0443\u0433\u043e\u043c\u0443. \u041d\u0430 \u0442\u0435 \u0436\u0435 32 \u0441\u0445\u0435\u043c\u044b \/ 401 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u0432 TSUM \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u2014\u00a02 \u043f\u0435\u0440\u0432\u0438\u0447\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0430:\u00a0pk__objects\u00a0\u0438\u00a0pk__values. \u041f\u043e\u043b\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0437\u0430\u0448\u0438\u0442 \u0432\u00a0redbPostgre.sql\u00a0\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 50 \u0448\u0442\u0443\u043a\u00a0\u043d\u0430 \u0432\u0441\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443. \u041d\u0435 \u043d\u0430 \u043a\u043b\u0430\u0441\u0441. \u041d\u0430 \u0441\u0438\u0441\u0442\u0435\u043c\u0443.\u0418 \u0437\u0434\u0435\u0441\u044c \u0432\u0430\u0436\u043d\u043e \u0441\u0440\u0430\u0437\u0443 \u0441\u043d\u044f\u0442\u044c \u043e\u0434\u043d\u043e \u043d\u0435\u0434\u043e\u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435. \u0412 \u0441\u0442\u0430\u0442\u044c\u0435 1 \u044f \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0438\u043b 13 \u0442\u0430\u0431\u043b\u0438\u0446 REDB, \u0438 \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044c \u043b\u0435\u0433\u043a\u043e \u0443\u043d\u043e\u0441\u0438\u0442 \u043c\u044b\u0441\u043b\u044c \u00ab\u0437\u043d\u0430\u0447\u0438\u0442 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0441\u0445\u0435\u043c\u0443 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0432\u0441\u0435 13\u00bb. \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u043f\u043e\u0434 \u0431\u0438\u0437\u043d\u0435\u0441-\u0434\u0430\u043d\u043d\u044b\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430 \u0432 \u0433\u043e\u0440\u044f\u0447\u0435\u043c \u043f\u0443\u0442\u0438 \u0430\u043a\u0442\u0438\u0432\u043d\u044b \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u0442\u0430\u0431\u043b\u0438\u0446. \u0420\u0430\u0441\u043a\u043b\u0430\u0434\u043a\u0430 \u0442\u0430\u043a\u0430\u044f:\u0425\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 \u2014 2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:\u00a0objects\u00a0(\u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a) \u0438\u00a0values\u00a0(\u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0441\u0432\u043e\u0439\u0441\u0442\u0432). \u041b\u044e\u0431\u043e\u0439\u00a0Query&lt;T&gt;(), \u043b\u044e\u0431\u043e\u0439\u00a0SaveAsync, \u043b\u044e\u0431\u043e\u0439 LINQ-\u0444\u0438\u043b\u044c\u0442\u0440 \u043f\u0440\u0438\u0437\u0435\u043c\u043b\u044f\u0435\u0442\u0441\u044f \u0438\u043c\u0435\u043d\u043d\u043e \u0441\u044e\u0434\u0430.\u0421\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a\u0438 \u2014 2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:\u00a0lists\u00a0\u0438\u00a0list_items. \u042d\u0442\u043e\u00a0RedbListItem-\u043f\u043e\u043b\u044f (Driver, Vehicle, ShippingPoint \u0438 \u0442.\u0434.), \u043e\u043d\u0438 \u0448\u0430\u0440\u044f\u0442\u0441\u044f \u043c\u0435\u0436\u0434\u0443 \u043a\u043b\u0430\u0441\u0441\u0430\u043c\u0438 \u0438 \u043d\u0435 \u0440\u0430\u0441\u0442\u0443\u0442 \u043e\u0442 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043d\u043e\u0432\u043e\u0439 \u0431\u0438\u0437\u043d\u0435\u0441-\u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0438.RTTI \/ \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 \u0441\u0445\u0435\u043c \u2014 3 \u0442\u0430\u0431\u043b\u0438\u0446\u044b:\u00a0types\u00a0(\u043f\u0440\u0438\u043c\u0438\u0442\u0438\u0432\u043d\u044b\u0435 \u0442\u0438\u043f\u044b),\u00a0schemes\u00a0(\u043a\u043b\u0430\u0441\u0441\u044b),\u00a0structures\u00a0(\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432). \u042d\u0442\u043e \u043a\u043e\u0434 \u0434\u0432\u0438\u0436\u043a\u0430 \u0447\u0438\u0442\u0430\u0435\u0442 \u0447\u0435\u0440\u0435\u0437\u00a0scheme_metadata_cache, \u0431\u0438\u0437\u043d\u0435\u0441-\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0438\u0445 \u043d\u0435 \u0442\u0440\u043e\u0433\u0430\u044e\u0442.\u041e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0435 \u2014 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430:\u00a0users,\u00a0roles,\u00a0permissions,\u00a0links,\u00a0dependencies,\u00a0functions,\u00a0schememetadata_cache, soft-delete \u043d\u0430\u00a0@@__deleted. \u042d\u0442\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043d\u0435 \u0440\u0430\u0441\u0442\u0443\u0442 \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0431\u0438\u0437\u043d\u0435\u0441-\u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0438 \u0432 \u0433\u043e\u0440\u044f\u0447\u0435\u043c \u043f\u0443\u0442\u0438 \u043d\u0435 \u0443\u0447\u0430\u0441\u0442\u0432\u0443\u044e\u0442.\u0418\u0442\u043e\u0433\u043e: \u043a\u0430\u043a\u043e\u0439 \u0431\u044b \u043a\u043b\u0430\u0441\u0441 \u043d\u0438 \u043f\u0438\u0441\u0430\u043b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0432\u00a0tsum.Domain, \u0435\u0433\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u0441\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0432\u00a02 \u0442\u0430\u0431\u043b\u0438\u0446\u044b\u00a0(_objects\u00a0+\u00a0_values); \u0441\u0441\u044b\u043b\u043e\u0447\u043d\u044b\u0435 \u043f\u043e\u043b\u044f \u0431\u044c\u044e\u0442 \u0432\u00a02\u00a0\u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u044b\u0435; \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0435 \u0441\u0445\u0435\u043c\u044b \u2014 \u0432\u00a03\u00a0RTTI-\u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u0428\u0435\u0441\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u043d\u0430 5 \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0438 \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u043d\u0430 500. \u042d\u0442\u043e \u0438 \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442 \u00ab\u0438\u043d\u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u043e\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u00bb \u2014 \u0440\u0435\u0447\u044c \u043d\u0435 \u043f\u0440\u043e \u00ab\u0432\u0441\u0435 13 \u0442\u0430\u0431\u043b\u0438\u0446 \u043d\u0430 \u0441\u0445\u0435\u043c\u0443\u00bb, \u0430 \u043f\u0440\u043e \u0442\u043e, \u0447\u0442\u043e\u00a0\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0442\u0430\u0431\u043b\u0438\u0446 \u0434\u043b\u044f \u0431\u0438\u0437\u043d\u0435\u0441-\u0434\u0430\u043d\u043d\u044b\u0445 = 2, \u0438 \u043e\u043d \u043d\u0435 \u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f.\u041a\u043e\u0433\u0434\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u0432\u00a0tsum.Domain\u00a033-\u0439 \u043a\u043b\u0430\u0441\u0441 \u2014 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440,\u00a0WarehouseSlot\u00a0\u2014 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0438 \u0432 \u0411\u0414 \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f:\u043e\u0434\u043d\u0430 \u0441\u0442\u0440\u043e\u043a\u0430 \u0432\u00a0_schemes,N \u0441\u0442\u0440\u043e\u043a \u0432\u00a0_structures\u00a0(\u043f\u043e \u043e\u0434\u043d\u043e\u0439 \u043d\u0430 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e),\u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0439 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432. \u0421\u043e\u0432\u0441\u0435\u043c.\u041f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0432\u0435\u0441\u044c \u0441\u043f\u0435\u043a\u0442\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u043a \u043d\u043e\u0432\u043e\u043c\u0443 \u043a\u043b\u0430\u0441\u0441\u0443 \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0442\u0435\u043c \u0436\u0435 \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0430\u00a0objects\u00a0\u0438\u00a0values, \u0447\u0442\u043e \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u043b \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0435 32. \u041f\u043e\u0438\u0441\u043a \u043f\u043e \u043f\u043e\u043b\u044e\u00a0idscheme = ID(WarehouseSlot)\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u00a0IX__objects__schemes. \u041f\u043e\u0438\u0441\u043a \u043f\u043e \u0434\u0430\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u2014\u00a0IX__objects__scheme_date_create. \u041f\u043e\u0438\u0441\u043a \u043e\u0431\u044a\u0435\u043a\u0442\u0430 \u043f\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044e \u043a\u0430\u043a\u043e\u0433\u043e-\u0442\u043e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u2014\u00a0IX__values__structure_object_lookup. \u0414\u0435\u0440\u0435\u0432\u043e \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c-\u0440\u0435\u0431\u0451\u043d\u043e\u043a \u2014\u00a0IX__objects__scheme_parent.\u042d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u043e\u0435 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u043e, \u0440\u0430\u0434\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0441\u0442\u0430\u0442\u044c\u044f.\u00a0\u0418\u043d\u0434\u0435\u043a\u0441\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u043b\u0430\u043d \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0434\u0438\u0437\u0430\u0439\u043d\u0430 \u0434\u0432\u0438\u0436\u043a\u0430, \u0430 \u043d\u0435 \u0440\u0430\u0437\u043c\u0430\u0437\u0430\u043d \u043f\u043e \u0440\u0435\u043b\u0438\u0437\u0430\u043c \u0431\u0438\u0437\u043d\u0435\u0441-\u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f. \u0421\u043a\u0435\u043f\u0442\u0438\u043a \u0432\u043e\u0437\u0440\u0430\u0437\u0438\u0442: \u00ab\u041d\u043e \u044d\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430\u00a0_values\u00a0\u0431\u0443\u0434\u0443\u0442 \u0445\u0443\u0436\u0435, \u0447\u0435\u043c \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u0435 \u043f\u043e\u043b\u0435 \u0432 EF-\u0441\u0445\u0435\u043c\u0435\u00bb. \u041d\u0435 \u0431\u0443\u0434\u0443\u0442 \u2014 \u0438 \u043d\u0438\u0436\u0435 \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c, \u043f\u043e\u0447\u0435\u043c\u0443.\u0412 MSSQL \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0451 \u0442\u0430\u043a \u0436\u0435. \u042d\u0442\u043e \u0432\u0430\u0436\u043d\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c \u0432\u0441\u043b\u0443\u0445: \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440 \u043d\u0435 \u043f\u0440\u043e \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0443 Postgres. \u0412\u00a0redb.MSSql\/sql\/redbMSSQL.sql\u00a0\u043b\u0435\u0436\u0438\u0442 \u0437\u0435\u0440\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432, \u0441 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u043e\u0442\u043b\u0438\u0447\u0438\u044f\u043c\u0438 (\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u043c \u0440\u0430\u0437\u0434\u0435\u043b\u0435). \u0410\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u043d\u044b\u0439 \u043f\u0440\u0438\u0451\u043c \u2014 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043d\u0430 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0441\u0445\u0435\u043c\u0435, \u0430 \u043d\u0435 \u043d\u0430 \u0431\u0438\u0437\u043d\u0435\u0441-\u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445 \u2014 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043c\u0435\u0436\u0434\u0443 \u0434\u0432\u0438\u0436\u043a\u0430\u043c\u0438 \u0431\u0435\u0437 \u043f\u043e\u0442\u0435\u0440\u044c.\u041a\u0430\u0440\u0442\u0430 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432\u00a0redbPostgre.sql\u0415\u0441\u043b\u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u044c DDL \u0438 \u0447\u0438\u0442\u0430\u0442\u044c \u0441\u0432\u0435\u0440\u0445\u0443 \u0432\u043d\u0438\u0437 \u2014 \u0443\u0432\u0438\u0434\u0438\u0442\u0435 ~50 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u0432\u043f\u0435\u0440\u0435\u043c\u0435\u0448\u043a\u0443. \u0427\u0442\u043e\u0431\u044b \u0438\u0445 \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c, \u0443\u0434\u043e\u0431\u043d\u0435\u0435 \u0441\u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u00a0\u043f\u043e \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u044e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f, \u0430 \u043d\u0435 \u043f\u043e \u0442\u0430\u0431\u043b\u0438\u0446\u0435. \u0427\u0442\u043e \u0438 \u0441\u0434\u0435\u043b\u0430\u0435\u043c.1. \u0423\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438 \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u044c \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 (_values)\u0422\u0440\u0438 partial-unique \u0438\u043d\u0434\u0435\u043a\u0441\u0430, \u043a\u0430\u0436\u0434\u044b\u0439 \u043f\u043e\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u0441\u0432\u043e\u0439 \u0441\u043b\u0443\u0447\u0430\u0439:&#8212; \u0421\u043a\u0430\u043b\u044f\u0440\u043d\u044b\u0435 \u043f\u043e\u043b\u044f: \u043e\u0434\u0438\u043d \u043e\u0431\u044a\u0435\u043a\u0442 \u2014 \u043e\u0434\u043d\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u044fCREATE UNIQUE INDEX UIX__values__structure_objectON _values (_id_structure, _id_object)WHERE _array_index IS NULL AND _array_parent_id IS NULL;&#8212; \u041c\u0430\u0440\u043a\u0435\u0440 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430\/\u043c\u0430\u0441\u0441\u0438\u0432\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044fCREATE UNIQUE INDEX UIX__values__structure_object_parentON _values (_id_structure, _id_object, _array_parent_id)WHERE _array_index IS NULL AND _array_parent_id IS NOT NULL;&#8212; \u042d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438 \u043f\u043e \u043f\u043e\u0437\u0438\u0446\u0438\u0438\/\u043a\u043b\u044e\u0447\u0443CREATE UNIQUE INDEX UIX__values__structure_object_array_indexON _values (_id_structure, _id_object, _array_parent_id, _array_index)WHERE _array_index IS NOT NULL;\u0417\u0430\u0447\u0435\u043c \u0442\u0440\u0438, \u0430 \u043d\u0435 \u043e\u0434\u0438\u043d. \u041a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 \u044d\u0442\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u0432\u00a0_values\u00a0\u0438\u043c\u0435\u0435\u0442 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043f\u043e \u0440\u0430\u0437\u043d\u043e\u043c\u0443 \u043d\u0430\u0431\u043e\u0440\u0443 \u043a\u043e\u043b\u043e\u043d\u043e\u043a. \u0421\u043a\u0430\u043b\u044f\u0440 \u2014 \u043f\u043e\u00a0(structure, object). \u041c\u0430\u0440\u043a\u0435\u0440 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f\u00a0parent. \u042d\u043b\u0435\u043c\u0435\u043d\u0442 \u043c\u0430\u0441\u0441\u0438\u0432\u0430\/\u0441\u043b\u043e\u0432\u0430\u0440\u044f \u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f\u00a0index. \u041e\u0434\u0438\u043d \u043e\u0431\u0449\u0438\u0439 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0438\u043d\u0434\u0435\u043a\u0441 \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u0435\u043d (NULL-\u044b \u043b\u043e\u043c\u0430\u043b\u0438 \u0431\u044b \u0441\u0435\u043c\u0430\u043d\u0442\u0438\u043a\u0443), \u0430 \u0442\u0440\u0438 partial \u2014 \u0442\u043e\u0447\u043d\u043e \u043b\u043e\u0436\u0430\u0442\u0441\u044f \u043d\u0430 \u0444\u0438\u0437\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u043c\u043e\u0434\u0435\u043b\u044c.\u0411\u043e\u043d\u0443\u0441-\u044d\u0444\u0444\u0435\u043a\u0442: \u0434\u0435\u0440\u0435\u0432\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043c\u0435\u043d\u044c\u0448\u0435, \u0447\u0435\u043c \u0443 \u043e\u0434\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u043d\u043e\u0433\u043e \u2014 \u043a\u0430\u0436\u0434\u044b\u0439 partial \u0445\u0440\u0430\u043d\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u0434\u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0440\u043e\u043a. \u041d\u0430 9.7M \u0441\u0442\u0440\u043e\u043a \u044d\u0442\u043e \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043f\u0440\u043e\u0446\u0435\u043d\u0442\u043e\u0432 \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u0438 \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446.2. Facet search \u2014 \u0441\u0430\u043c\u043e\u0435 \u0433\u043e\u0440\u044f\u0447\u0435\u0435 \u043c\u0435\u0441\u0442\u043eFacet-\u0437\u0430\u043f\u0440\u043e\u0441 REDB \u2014 \u044d\u0442\u043e \u00ab\u043d\u0430\u0439\u0434\u0438 \u043e\u0431\u044a\u0435\u043a\u0442\u044b, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u043e\u043b\u0435 X \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 Y\u00bb. \u0412 \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u0445 SQL:SELECT v._id_object FROM _values vWHERE v._id_structure = @structure_id  AND v._Long &gt; 80000\u042d\u0442\u043e\u0442 \u0448\u0430\u0431\u043b\u043e\u043d \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0441\u0442\u0430\u0432\u043d\u044b\u043c \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u043c:CREATE INDEX IX__values__structure_object_lookupON _values (_id_structure, _id_object,            _Long, _DateTimeOffset, _Boolean, _Double, _Guid, _Numeric, _ListItem, _Object);\u0412\u0441\u0435 \u0442\u0438\u043f\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438 (\u043a\u0440\u043e\u043c\u0435\u00a0_String\u00a0\u2014 \u043f\u0440\u043e \u043d\u0435\u0451 \u043d\u0438\u0436\u0435) \u043f\u043e\u043f\u0430\u0434\u0430\u044e\u0442 \u0432 \u043a\u043b\u044e\u0447. Index Only Scan: Postgres \u043d\u0430\u0445\u043e\u0434\u0438\u0442 \u043d\u0443\u0436\u043d\u044b\u0435 \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u0437\u0430\u0431\u0438\u0440\u0430\u0435\u0442 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u00a0\u043f\u0440\u044f\u043c\u043e \u0438\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u0430, \u0431\u0435\u0437 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u043a heap.\u041f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0436\u0438\u0432\u0443\u0442 covering-\u0438\u043d\u0434\u0435\u043a\u0441\u044b \u0441\u00a0INCLUDE:CREATE INDEX IX__values__object_structure_lookupON _values (_id_object, _id_structure, _array_index)INCLUDE (_Long, _Double, _DateTimeOffset, _Boolean, _Guid, _Numeric, _ListItem,&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-482888","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/482888","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=482888"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/482888\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=482888"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=482888"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=482888"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}