Документация по PostgreSQL 9.4.1 | |||
---|---|---|---|
Пред. | Уровень выше | Приложение E. Дополнительно поставляемые модули | След. |
E.4. btree_gin
Модуль btree_gin предоставляет показательные классы операторов GIN, реализующие поведение, подобное тому, что реализуют обычные классы B-дерева, для типов данных int2, int4, int8, float4, float8, timestamp with time zone, timestamp without time zone, time with time zone, time without time zone, date, interval, oid, money, "char", varchar, text, bytea, bit, varbit, macaddr, inet и cidr.
Вообще говоря, эти классы операторов не будут работать быстрее аналогичных стандартных методов индекса-B-дерева, и им не хватает одной важной возможности стандартной реализации B-дерева: возможности ограничивать уникальность. Тем не менее, их можно применять для тестирования GIN или взять за основу для разработки других классов операторов GIN. Также, для запросов, где проверяется и колонка с индексом GIN, и колонка с индексом-B-деревом, может быть более эффективным создать многоколоночный индекс GIN, который использует один из этих классов операторов, чем использовать два отдельных индекса, выборку из которых придётся объединять, вычисляя AND битовых карт.
E.4.1. Пример использования
CREATE TABLE test (a int4); -- создать индекс CREATE INDEX testidx ON test USING gin (a); -- запрос SELECT * FROM test WHERE a < 10;
E.4.2. Авторы
Фёдор Сигаев (<teodor@stack.net>
) и Олег Бартунов (<oleg@sai.msu.su>
). Подробности можно найти на странице http://www.sai.msu.su/~megera/oddmuse/index.cgi/Gin.
Пред. | Начало | След. |
auto_explain | Уровень выше | btree_gist |