Sophie

Sophie

distrib > Fedora > 18 > x86_64 > media > updates > by-pkgid > e450e7f3d6075c4a54de19e68d38177f > files > 473

groonga-doc-3.0.5-1.fc18.x86_64.rpm

.. -*- rst -*-

.. highlightlang:: none

Tables
======

Summary
-------

Table in groonga manages relation between ID and key. Groonga provides
four table types. They are ``TABLE_NO_KEY``, ``TABLE_HASH_KEY``,
``TABLE_PAT_KEY`` and ``TABLE_DAT_KEY``.

All tables except ``TABLE_NO_KEY`` provides both fast ID search by key
and fast key search by ID. ``TABLE_NO_KEY`` doesn't support
key. ``TABLE_NO_KEY`` only manages ID. So ``TABLE_NO_KEY`` doesn't
provides ID search and key search.

Characteristics
---------------

Here is a chracteristic table of all tables in groonga. (``TABLE_``
prefix is omitted in the table.)

+--------------+------------+--------------+-------------+-------------+
|              | ``NO_KEY`` | ``HASH_KEY`` | ``PAT_KEY`` | ``DAT_KEY`` |
+==============+============+==============+=============+=============+
| Data         | Array      | Hash table   | Patricia    | Double      |
| structure    |            |              | trie        | array       |
|              |            |              |             | trie        |
+--------------+------------+--------------+-------------+-------------+
| ID           | o          | o            | o           | o           |
| support      |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Key          | x          | o            | o           | o           |
| support      |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Value        | o          | o            | o           | x           |
| support      |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Key -> ID    | \-         | oo           | x           | o           |
| speed        |            |              |             |             |
|              |            |              |             |             |
| * o: fast    |            |              |             |             |
| * x: slow    |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Update speed | ooo        | o            | o           | x           |
|              |            |              |             |             |
| * o: fast    |            |              |             |             |
| * x: slow    |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Size         | ooo        | o            | oo          | x           |
|              |            |              |             |             |
| * o: small   |            |              |             |             |
| * x: large   |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Key          | \-         | x            | x           | o           |
| update       |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Common       | \-         | x            | o           | o           |
| prefix       |            |              |             |             |
| search       |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Predictive   | \-         | x            | o           | o           |
| search       |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+
| Range        | \-         | x            | o           | o           |
| search       |            |              |             |             |
+--------------+------------+--------------+-------------+-------------+

``TABLE_NO_KEY``
^^^^^^^^^^^^^^^^

``TABLE_NO_KEY`` is very fast and very small but it doesn't support
key. ``TABLE_NO_KEY`` is a only table that doesn't support key.

You cannot use ``TABLE_NO_KEY`` for lexicon for fulltext search
because lexicon stores tokens as key. ``TABLE_NO_KEY`` is useful for
no key records such as log.

``TABLE_HASH_KEY``
^^^^^^^^^^^^^^^^^^

``TABLE_HASH_KEY`` is fast but it doesn't support advanced search
functions such as common prefix search and predictive search.

``TABLE_HASH_KEY`` is useful for index for exact search such as tag
search.

``TABLE_PAT_KEY``
^^^^^^^^^^^^^^^^^

``TABLE_PAT_KEY`` is small and supports advanced search functions.

``TABLE_PAT_KEY`` is useful for lexicon for fulltext search and
index for range search.

``TABLE_DAT_KEY``
^^^^^^^^^^^^^^^^^

``TABLE_DAT_KEY`` is fast and supports key update but it is large. It
is not suitable for storing many records. ``TABLE_DAT_KEY`` is a only
table that supports key update.

``TABLE_DAT_KEY`` is used in groonga database. Groonga database needs
to convert object name such as ``ShortText``, ``TokenBigram`` and
table names to object ID. And groonga database needs to rename object
name. Those features are implemented by ``TABLE_DAT_KEY``. The number
of objects is small. So large data size demerit of ``TABLE_DAT_KEY``
can be ignored.

Record ID
---------

Record ID is assigned automatically. You cannot assign record ID.

Record ID of deleted record may be reused.

Valid record ID range is between 1 and 268435455. (1 and 268435455 are
valid IDs.)

Persistent table and temporary table
------------------------------------

Table is persistent table or temporary table.

Persistent table
^^^^^^^^^^^^^^^^

Persistent table is named and registered to database. Records in
persistent table aren't deleted after closing table or
database.

Persistent table can be created by
:doc:`/reference/commands/table_create` command.

Temporary table
^^^^^^^^^^^^^^^

Temporary table is anonymous. Records in temporary table are deleted
after closing table. Temporary table is used to store search result,
sort result, group (drilldown) result and so on. ``TABLE_HASH_KEY`` is
used for search result and group result. ``TABLE_NO_KEY`` is used for
sort result.

Limitations
-----------

The max number of records is 268435455. You cannot add 268435456 or
more records in a table.

The max number of a key size is 4096byte. You cannot use 4097byte or
larger key. You can use column instead of key for 4097byte or larger
size data. ``Text`` and ``LargeText`` types supports 4097byte or
larger size data.

The max number of total key size is 4GiB. You need to split a table,
split a database (sharding) or reduce each key size to handle 4GiB or
more larger total key size.

See also
--------

* :doc:`/reference/commands/table_create`