F.22. hstore
ÐÑÐ¾Ñ Ð¼Ð¾Ð´ÑÐ»Ñ ÑеализÑÐµÑ Ñип даннÑÑ
hstore Ð´Ð»Ñ Ñ
ÑÐ°Ð½ÐµÐ½Ð¸Ñ Ð¿Ð°Ñ ÐºÐ»ÑÑ-знаÑение внÑÑÑи одного знаÑÐµÐ½Ð¸Ñ Postgres Pro. ÐÑо Ð¼Ð¾Ð¶ÐµÑ Ð±ÑÑÑ Ð¿Ð¾Ð»ÐµÐ·Ð½Ð¾ в ÑамÑÑ
ÑазнÑÑ
ÑÑенаÑиÑÑ
, напÑÐ¸Ð¼ÐµÑ Ð´Ð»Ñ Ñ
ÑÐ°Ð½ÐµÐ½Ð¸Ñ ÑÑÑок Ñо множеÑÑвом Ñедко анализиÑÑемÑÑ
аÑÑибÑÑов или ÑаÑÑиÑно ÑÑÑÑкÑÑÑиÑованнÑÑ
даннÑÑ
. ÐлÑÑи и знаÑÐµÐ½Ð¸Ñ Ð·Ð°Ð´Ð°ÑÑÑÑ Ð¿ÑоÑÑÑми ÑекÑÑовÑми ÑÑÑоками.
ÐаннÑй модÑÐ»Ñ ÑÑиÑаеÑÑÑ Â«Ð´Ð¾Ð²ÐµÑеннÑм», Ñо еÑÑÑ ÐµÐ³Ð¾ могÑÑ ÑÑÑанавливаÑÑ Ð¾Ð±ÑÑнÑе полÑзоваÑели, имеÑÑие пÑаво CREATE в ÑекÑÑей базе даннÑÑ
.
F.22.1. ÐнеÑнее пÑедÑÑавление hstore
ТекÑÑовое пÑедÑÑавление Ñипа hstore, пÑименÑемое Ð´Ð»Ñ Ð²Ð²Ð¾Ð´Ð° и вÑвода, вклÑÑÐ°ÐµÑ Ð½Ð¾Ð»Ñ Ð¸Ð»Ð¸ более Ð¿Ð°Ñ ÐºÐ»ÑÑ => знаÑение, ÑазделÑннÑÑ
запÑÑÑми. ÐеÑколÑко пÑимеÑов:
k => v foo => bar, baz => whatever "1-a" => "anything at all"
ÐоÑÑдок Ð¿Ð°Ñ Ð½Ðµ Ð¸Ð¼ÐµÐµÑ Ð·Ð½Ð°ÑÐµÐ½Ð¸Ñ (и Ð¼Ð¾Ð¶ÐµÑ Ð½Ðµ воÑпÑоизводиÑÑÑÑ Ð¿Ñи вÑводе). ÐÑÐ¾Ð±ÐµÐ»Ñ Ð¼ÐµÐ¶Ð´Ñ Ð¿Ð°Ñами и вокÑÑг знака => игноÑиÑÑÑÑÑÑ. ÐлÑÑи и знаÑениÑ, ÑодеÑжаÑие пÑобелÑ, запÑÑÑе и знаки = или >, нÑжно заклÑÑаÑÑ Ð² двойнÑе кавÑÑки. ÐÑли в клÑÑ Ð¸Ð»Ð¸ знаÑение нÑжно вÑÑавиÑÑ Ñимвол кавÑÑек или обÑаÑнÑÑ ÐºÐ¾ÑÑÑ ÑеÑÑÑ, добавÑÑе пеÑед ним обÑаÑнÑÑ ÐºÐ¾ÑÑÑ ÑеÑÑÑ.
ÐÑе клÑÑи в hstore ÑникалÑнÑ. ÐÑли Ð²Ñ Ð¾Ð±ÑÑвиÑе Ñип hstore Ñ Ð´ÑблиÑÑÑÑимиÑÑ ÐºÐ»ÑÑами, в hstore бÑÐ´ÐµÑ ÑоÑ
ÑанÑн ÑолÑко один клÑÑ Ð±ÐµÐ· гаÑанÑии опÑеделÑнного вÑбоÑа:
SELECT 'a=>1,a=>2'::hstore; hstore ---------- "a"=>"1"
РкаÑеÑÑве знаÑÐµÐ½Ð¸Ñ (но не клÑÑа) Ð¼Ð¾Ð¶ÐµÑ Ð·Ð°Ð´Ð°Ð²Ð°ÑÑÑÑ SQL NULL. ÐапÑимеÑ:
key => NULL
РклÑÑевом Ñлове NULL ÑегиÑÑÑ Ð½Ðµ Ð¸Ð¼ÐµÐµÑ Ð·Ð½Ð°ÑениÑ. ÐÑли ÑÑебÑеÑÑÑ, ÑÑÐ¾Ð±Ñ ÑекÑÑ NULL воÑпÑинималÑÑ ÐºÐ°Ðº обÑÑÐ½Ð°Ñ ÑÑÑока «NULL», заклÑÑиÑе его в кавÑÑки.
ÐÑимеÑание
УÑÑиÑе, ÑÑо когда ÑекÑÑовÑй ÑоÑÐ¼Ð°Ñ hstore иÑполÑзÑеÑÑÑ Ð´Ð»Ñ Ð²Ð²Ð¾Ð´Ð° даннÑÑ
, он пÑименÑеÑÑÑ Ð´Ð¾ обÑабоÑки кавÑÑек или ÑпеÑÑимволов. Таким обÑазом, еÑли знаÑение hstore пеÑедаÑÑÑÑ Ð² паÑамеÑÑе, дополниÑелÑÐ½Ð°Ñ Ð¾Ð±ÑабоÑка не ÑÑебÑеÑÑÑ. Ðо еÑли Ð²Ñ Ð¿ÐµÑедаÑÑе его в виде ÑÑÑоковой конÑÑанÑÑ, Ñо вÑе ÑÐ¸Ð¼Ð²Ð¾Ð»Ñ Ð°Ð¿Ð¾ÑÑÑоÑов и (в завиÑимоÑÑи Ð¾Ñ Ð¿Ð°ÑамеÑÑа конÑигÑÑаÑии standard_conforming_strings) обÑаÑной коÑой ÑеÑÑÑ Ð½Ñжно коÑÑекÑно ÑкÑаниÑоваÑÑ. ÐодÑобнее о запиÑи ÑÑÑоковÑÑ
конÑÑÐ°Ð½Ñ Ð¼Ð¾Ð¶Ð½Ð¾ ÑзнаÑÑ Ð² ÐодÑазделе 4.1.2.1.
ÐÑи вÑводе знаÑÐµÐ½Ð¸Ñ Ð¸ клÑÑи вÑегда заклÑÑаÑÑÑÑ Ð² кавÑÑки, даже когда без ÑÑого можно обойÑиÑÑ.
F.22.2. ÐпеÑаÑоÑÑ Ð¸ ÑÑнкÑии hstore
РеализованнÑе в модÑле hstore опеÑаÑоÑÑ Ð¿ÐµÑеÑиÑÐ»ÐµÐ½Ñ Ð² ТаблиÑе F.11, ÑÑнкÑии â в ТаблиÑе F.12.
ТаблиÑа F.11. ÐпеÑаÑоÑÑ hstore
ÐпеÑаÑÐ¾Ñ ÐпиÑание ÐÑимеÑÑ |
|---|
ÐÑдаÑÑ Ð·Ð½Ð°Ñение Ð´Ð»Ñ Ð·Ð°Ð´Ð°Ð½Ð½Ð¾Ð³Ð¾ клÑÑа, или
|
ÐÑдаÑÑ Ð·Ð½Ð°ÑениÑ, ÑвÑзаннÑе Ñ Ð·Ð°Ð´Ð°Ð½Ð½Ñми клÑÑами, или
|
СоединÑÐµÑ Ð´Ð²Ð° набоÑа
|
ÐабоÑ
|
ÐабоÑ
|
ÐабоÑ
|
ÐевÑй опеÑанд ÑодеÑÐ¶Ð¸Ñ Ð¿ÑавÑй?
|
ÐевÑй опеÑанд ÑодеÑжиÑÑÑ Ð² пÑавом?
|
УдалÑÐµÑ ÐºÐ»ÑÑ Ð¸Ð· левого опеÑанда.
|
УдалÑÐµÑ ÐºÐ»ÑÑи из левого опеÑанда.
|
УдалÑÐµÑ Ð¸Ð· левого опеÑанда паÑÑ ÐºÐ»ÑÑ-знаÑение, ÑовпадаÑÑие Ñ Ð¿Ð°Ñами в пÑавом.
|
ÐаменÑÐµÑ Ð¿Ð¾Ð»Ñ Ð² левом опеÑанде, имеÑÑем ÑоÑÑавной Ñип, ÑооÑвеÑÑÑвÑÑÑими знаÑениÑми из
|
ÐÑеобÑазÑеÑ
|
ÐÑеобÑазÑеÑ
|
ТаблиÑа F.12. ФÑнкÑии hstore
Ðомимо ÑÑиÑ
опеÑаÑоÑов и ÑÑнкÑий, Ñо знаÑениÑми Ñипа hstore ÑабоÑÐ°ÐµÑ Ð¾Ð¿ÐµÑаÑÐ¸Ñ Ð¾Ð±ÑаÑÐµÐ½Ð¸Ñ Ð¿Ð¾ индекÑÑ, наделÑÑÑÐ°Ñ Ð¸Ñ
каÑеÑÑвами аÑÑоÑиаÑивнÑÑ
маÑÑивов. Ðожно ÑказаÑÑ ÑолÑко один Ð¸Ð½Ð´ÐµÐºÑ Ñипа text; он воÑпÑинимаеÑÑÑ ÐºÐ°Ðº клÑÑ, Ð´Ð»Ñ ÐºÐ¾ÑоÑого ÑоÑ
ÑанÑеÑÑÑ Ð¸Ð»Ð¸ извлекаеÑÑÑ ÑооÑвеÑÑÑвÑÑÑее знаÑение. ÐапÑимеÑ:
CREATE TABLE mytable (h hstore);
INSERT INTO mytable VALUES ('a=>b, c=>d');
SELECT h['a'] FROM mytable;
h
---
b
(1 row)
UPDATE mytable SET h['c'] = 'new';
SELECT h FROM mytable;
h
----------------------
"a"=>"b", "c"=>"new"
(1 row) ÐÑи обÑаÑении по индекÑÑ Ð²Ð¾Ð·Ð²ÑаÑаеÑÑÑ NULL, еÑли Ð¸Ð½Ð´ÐµÐºÑ â NULL или ÑказаннÑй клÑÑ Ð½Ðµ ÑÑÑеÑÑвÑÐµÑ Ð² hstore. (Таким обÑазом, обÑаÑение по индекÑÑ Ð½Ðµ ÑилÑно оÑлиÑаеÑÑÑ Ð¾Ñ Ð¾Ð¿ÐµÑаÑоÑа ->.) Ðзменение по индекÑÑ Ð½Ðµ вÑполнÑеÑÑÑ, еÑли Ð¸Ð½Ð´ÐµÐºÑ â NULL; в оÑÑалÑнÑÑ
ÑлÑÑаÑÑ
заменÑеÑÑÑ Ð·Ð½Ð°Ñение Ñказанного клÑÑа (еÑли Ñакой клÑÑ Ð½Ðµ ÑÑÑеÑÑвÑеÑ, он добавлÑеÑÑÑ Ð² hstore).
F.22.3. ÐндекÑÑ
Тип hstore поддеÑÐ¶Ð¸Ð²Ð°ÐµÑ Ð¸Ð½Ð´ÐµÐºÑÑ GiST и GIN Ð´Ð»Ñ Ð¾Ð¿ÐµÑаÑоÑов @>, ?, ?& и ?|. ÐапÑимеÑ:
CREATE INDEX hidx ON testhstore USING GIST (h); CREATE INDEX hidx ON testhstore USING GIN (h);
ÐлаÑÑ Ð¾Ð¿ÐµÑаÑоÑов GiST gist_hstore_ops аппÑокÑимиÑÑÐµÑ Ð½Ð°Ð±Ð¾Ñ Ð¿Ð°Ñ ÐºÐ»ÑÑ-знаÑение в виде ÑигнаÑÑÑÑ Ð±Ð¸Ñовой каÑÑÑ. Рего необÑзаÑелÑном ÑелоÑиÑленном паÑамеÑÑе siglen можно задаÑÑ ÑÐ°Ð·Ð¼ÐµÑ ÑигнаÑÑÑÑ Ð² байÑаÑ
. ÐаÑамеÑÑ Ð¼Ð¾Ð¶ÐµÑ Ð¿ÑинимаÑÑ Ð·Ð½Ð°ÑÐµÐ½Ð¸Ñ Ð¾Ñ 1 до 2024, по ÑмолÑÐ°Ð½Ð¸Ñ Ð¾Ð½ Ñавен 16. ÐÑи ÑвелиÑении ÑазмеÑа ÑигнаÑÑÑÑ Ð¿Ð¾Ð¸Ñк ÑабоÑÐ°ÐµÑ ÑоÑнее (ÑканиÑÑеÑÑÑ Ð¼ÐµÐ½ÑÑÐ°Ñ Ð¾Ð±Ð»Ð°ÑÑÑ Ð² индекÑе и менÑÑе ÑÑÑÐ°Ð½Ð¸Ñ ÐºÑÑи), но Ñам Ð¸Ð½Ð´ÐµÐºÑ ÑÑановиÑÑÑ Ð±Ð¾Ð»ÑÑе.
ÐÑÐ¸Ð¼ÐµÑ ÑÐ¾Ð·Ð´Ð°Ð½Ð¸Ñ Ñакого индекÑа Ñ Ð´Ð»Ð¸Ð½Ð¾Ð¹ ÑигнаÑÑÑÑ 32 байÑа:
CREATE INDEX hidx ON testhstore USING GIST (h gist_hstore_ops(siglen=32));
Тип hstore Ñакже поддеÑÐ¶Ð¸Ð²Ð°ÐµÑ Ð¸Ð½Ð´ÐµÐºÑÑ btree и hash Ð´Ð»Ñ Ð¾Ð¿ÐµÑаÑоÑа =. ÐÑо позволÑÐµÑ Ð¾Ð±ÑÑвлÑÑÑ ÑÑолбÑÑ hstore как ÑникалÑнÑе (UNIQUE) и иÑполÑзоваÑÑ Ð¸Ñ
в вÑÑажениÑÑ
GROUP BY, ORDER BY или DISTINCT. ÐоÑÑдок ÑоÑÑиÑовки знаÑений hstore не Ð¸Ð¼ÐµÐµÑ Ð¿ÑакÑиÑеÑкого ÑмÑÑла, но ÑÑи индекÑÑ Ð¼Ð¾Ð³ÑÑ Ð±ÑÑÑ Ð¿Ð¾Ð»ÐµÐ·Ð½Ñ Ð´Ð»Ñ Ð¿Ð¾Ð¸Ñка по ÑавенÑÑвÑ. ÐндекÑÑ Ð´Ð»Ñ ÑÑавнений (Ñ Ð¿Ð¾Ð¼Ð¾ÑÑÑ =) можно ÑоздаÑÑ Ñак:
CREATE INDEX hidx ON testhstore USING BTREE (h); CREATE INDEX hidx ON testhstore USING HASH (h);
F.22.4. ÐÑимеÑÑ
ÐÑиÑваивание знаÑÐµÐ½Ð¸Ñ ÑÑÑеÑÑвÑÑÑÐµÐ¼Ñ Ð¸Ð»Ð¸ Ð½Ð¾Ð²Ð¾Ð¼Ñ ÐºÐ»ÑÑÑ:
UPDATE tab SET h['c'] = '3';
ÐÑÑгой ÑпоÑоб ÑделаÑÑ Ñо же Ñамое:
UPDATE tab SET h = h || hstore('c', '3');ÐÑли в одной опеÑаÑии нÑжно добавиÑÑ Ð¸Ð»Ð¸ измениÑÑ Ð½ÐµÑколÑко клÑÑей, ÑÑÑекÑивнее иÑполÑзоваÑÑ ÐºÐ¾Ð½ÐºÐ°ÑенаÑиÑ, а не обÑаÑение по индекÑÑ:
UPDATE tab SET h = h || hstore(array['q', 'w'], array['11', '12']);
Удаление клÑÑа:
UPDATE tab SET h = delete(h, 'k1');
ÐÑиведение Ñипа record к ÑÐ¸Ð¿Ñ hstore:
CREATE TABLE test (col1 integer, col2 text, col3 text);
INSERT INTO test VALUES (123, 'foo', 'bar');
SELECT hstore(t) FROM test AS t;
hstore
---------------------------------------------
"col1"=>"123", "col2"=>"foo", "col3"=>"bar"
(1 row)ÐÑиведение Ñипа hstore к пÑедопÑеделÑÐ½Ð½Ð¾Ð¼Ñ ÑÐ¸Ð¿Ñ record:
CREATE TABLE test (col1 integer, col2 text, col3 text);
SELECT * FROM populate_record(null::test,
'"col1"=>"456", "col2"=>"zzz"');
col1 | col2 | col3
------+------+------
456 | zzz |
(1 row)Ðзменение ÑÑÑеÑÑвÑÑÑей запиÑи по даннÑм из hstore:
CREATE TABLE test (col1 integer, col2 text, col3 text); INSERT INTO test VALUES (123, 'foo', 'bar'); SELECT (r).* FROM (SELECT t #= '"col3"=>"baz"' AS r FROM test t) s; col1 | col2 | col3 ------+------+------ 123 | foo | baz (1 row)
F.22.5. СÑаÑиÑÑика
Тип hstore, вÑледÑÑвие пÑиÑÑÑей ÐµÐ¼Ñ Ð»Ð¸Ð±ÐµÑалÑноÑÑи, Ð¼Ð¾Ð¶ÐµÑ ÑодеÑжаÑÑ Ð¼Ð½Ð¾Ð¶ÐµÑÑво ÑамÑÑ
ÑазнÑÑ
клÑÑей. ÐонÑÑÐ¾Ð»Ñ Ð´Ð¾Ð¿ÑÑÑимоÑÑи клÑÑей ÑвлÑеÑÑÑ Ð·Ð°Ð´Ð°Ñей пÑиложениÑ. СледÑÑÑие пÑимеÑÑ Ð´ÐµÐ¼Ð¾Ð½ÑÑÑиÑÑÑÑ Ð½ÐµÑколÑко пÑиÑмов пÑовеÑки клÑÑей и полÑÑÐµÐ½Ð¸Ñ ÑÑаÑиÑÑики.
ÐÑоÑÑой пÑимеÑ:
SELECT * FROM each('aaa=>bq, b=>NULL, ""=>1');С ÑаблиÑей:
CREATE TABLE stat AS SELECT (each(h)).key, (each(h)).value FROM testhstore;
ÐкÑÑалÑÐ½Ð°Ñ ÑÑаÑиÑÑика:
SELECT key, count(*) FROM
(SELECT (each(h)).key FROM testhstore) AS stat
GROUP BY key
ORDER BY count DESC, key;
key | count
-----------+-------
line | 883
query | 207
pos | 203
node | 202
space | 197
status | 195
public | 194
title | 190
org | 189
...................F.22.6. СовмеÑÑимоÑÑÑ
ÐаÑÐ¸Ð½Ð°Ñ Ñ PostgreSQL 9.0, hstore иÑполÑзÑÐµÑ Ð²Ð½ÑÑÑеннее пÑедÑÑавление, оÑлиÑаÑÑееÑÑ Ð¾Ñ Ð¿ÑедÑдÑÑиÑ
веÑÑий. ÐÑо не пÑоблема пÑи обновлении пÑÑÑм вÑгÑÑзки/воÑÑÑÐ°Ð½Ð¾Ð²Ð»ÐµÐ½Ð¸Ñ Ð´Ð°Ð½Ð½ÑÑ
, Ñак как ÑекÑÑовое пÑедÑÑавление (иÑполÑзÑемое пÑи вÑгÑÑзке) не менÑеÑÑÑ.
Ð ÑлÑÑае двоиÑного Ð¾Ð±Ð½Ð¾Ð²Ð»ÐµÐ½Ð¸Ñ Ð¾Ð±ÑаÑÐ½Ð°Ñ ÑовмеÑÑимоÑÑÑ Ð¿Ð¾Ð´Ð´ÐµÑживаеÑÑÑ Ð±Ð»Ð°Ð³Ð¾Ð´Ð°ÑÑ ÑомÑ, ÑÑо новÑй код Ð¿Ð¾Ð½Ð¸Ð¼Ð°ÐµÑ Ð´Ð°Ð½Ð½Ñе в ÑÑаÑом ÑоÑмаÑе. ÐÑи Ñаком обновлении возможно неболÑÑое Ñнижение пÑоизводиÑелÑноÑÑи пÑи обÑабоÑке даннÑÑ
, коÑоÑÑе еÑÑ Ð½Ðµ бÑли Ð¸Ð·Ð¼ÐµÐ½ÐµÐ½Ñ Ð½Ð¾Ð²Ñм кодом. ÐÑе знаÑÐµÐ½Ð¸Ñ Ð² ÑÑолбÑе ÑаблиÑÑ Ð¼Ð¾Ð¶Ð½Ð¾ обновиÑÑ Ð¿ÑинÑдиÑелÑно, вÑполнив ÑледÑÑÑий опеÑаÑÐ¾Ñ UPDATE:
UPDATE tablename SET hstorecol = hstorecol || '';
ÐÑо можно ÑделаÑÑ Ð¸ Ñак:
ALTER TABLE tablename ALTER hstorecol TYPE hstore USING hstorecol || '';
ÐаÑÐ¸Ð°Ð½Ñ Ñ ÐºÐ¾Ð¼Ð°Ð½Ð´Ð¾Ð¹ ALTER TABLE ÑÑебÑÐµÑ Ð±Ð»Ð¾ÐºÐ¸Ñовки ÑаблиÑÑ Ð² Ñежиме ACCESS EXCLUSIVE, но не пÑÐ¸Ð²Ð¾Ð´Ð¸Ñ Ðº ÑаздÑÐ²Ð°Ð½Ð¸Ñ ÑаблиÑÑ Ð¸Ð·-за ÑÑаÑÑÑ
веÑÑий ÑÑÑок.
F.22.7. ТÑанÑÑоÑмаÑии
Также имеÑÑÑÑ Ð´Ð¾Ð¿Ð¾Ð»Ð½Ð¸ÑелÑнÑе ÑаÑÑиÑениÑ, ÑеализÑÑÑие ÑÑанÑÑоÑмаÑии Ñипа hstore Ð´Ð»Ñ ÑзÑков PL/Perl и PL/Python. РаÑÑиÑÐµÐ½Ð¸Ñ Ð´Ð»Ñ PL/Perl назÑваÑÑÑÑ hstore_plperl и hstore_plperlu Ð´Ð»Ñ Ð´Ð¾Ð²ÐµÑенного и недовеÑенного PL/Perl, ÑооÑвеÑÑÑвенно. ÐÑли Ð²Ñ ÑÑÑановиÑе ÑÑи ÑÑанÑÑоÑмаÑии и ÑкажеÑе иÑ
пÑи Ñоздании ÑÑнкÑии, знаÑÐµÐ½Ð¸Ñ hstore бÑдÑÑ Ð¾ÑобÑажаÑÑÑÑ Ð² Ñ
еÑи Perl. РаÑÑиÑÐµÐ½Ð¸Ñ Ð´Ð»Ñ PL/Python назÑваÑÑÑÑ hstore_plpythonu, hstore_plpython2u и hstore_plpython3u (ÑоглаÑÐµÐ½Ð¸Ñ Ð¾Ð± именовании, пÑинÑÑÑе Ð´Ð»Ñ Ð¸Ð½ÑеÑÑейÑа PL/Python, опиÑÐ°Ð½Ñ Ð² Разделе 45.1). ÐÑли Ð²Ñ Ð²Ð¾ÑполÑзÑеÑеÑÑ Ð¸Ð¼Ð¸, знаÑÐµÐ½Ð¸Ñ hstore бÑдÑÑ Ð¾ÑобÑажаÑÑÑÑ Ð² ÑловаÑи Python.
Ðнимание
РаÑÑиÑениÑ, ÑеализÑÑÑие ÑÑанÑÑоÑмаÑии, наÑÑоÑÑелÑно ÑекомендÑеÑÑÑ ÑÑÑанавливаÑÑ Ð² Ð¾Ð´Ð½Ñ ÑÑ
ÐµÐ¼Ñ Ñ hstore. ÐÑÐ±Ð¾Ñ ÐºÐ°ÐºÐ¾Ð¹-либо дÑÑгой ÑÑ
емÑ, коÑоÑÐ°Ñ Ð¼Ð¾Ð¶ÐµÑ ÑодеÑжаÑÑ Ð¾Ð±ÑекÑÑ, ÑозданнÑе злонамеÑеннÑм полÑзоваÑелем, ÑÑÐµÐ²Ð°Ñ ÑгÑозами безопаÑноÑÑи во вÑÐµÐ¼Ñ ÑÑÑановки ÑаÑÑиÑениÑ.
F.22.8. ÐвÑоÑÑ
Ðлег ÐаÑÑÑнов <[email protected]>, ÐоÑква, ÐоÑковÑкий ÐоÑÑдаÑÑÑвеннÑй УнивеÑÑиÑеÑ, РоÑÑиÑ
ФÑÐ´Ð¾Ñ Ð¡Ð¸Ð³Ð°ÐµÐ² <[email protected]>, ÐоÑква, ÐÐР«ÐелÑÑа-СоÑÑ», РоÑÑиÑ
ÐополниÑелÑнÑе ÑлÑÑÑÐµÐ½Ð¸Ñ Ð²Ð½ÑÑ ÐндÑÑ ÐиÑÑ <[email protected]>, ÐеликобÑиÑаниÑ