Skip to content

Latest commit

 

History

History
335 lines (276 loc) · 20.4 KB

SQL-FUNCTIONS.md

File metadata and controls

335 lines (276 loc) · 20.4 KB

SQL Functions

ZomboDB provides a number of utility and helper SQL functions.

FUNCTION zdb.internal_version() RETURNS text

Returns the version of the currently-installed ZomboDB shared library.

If this doesn't match SELECT zdb.schema_version() there will be problems.


FUNCTION zdb.schema_version() RETURNS text

Returns the schema version of the ZomboDB extension installed in the current database

If this doesn't match SELECT zdb.internal_version() there will be problems.


FUNCTION zdb.request(
	index regclass, 
	endpoint text, 
	method text DEFAULT 'GET', 
	post_data text DEFAULT NULL) 
RETURNS text

Make an arbitrary REST request to the Elasticsearch cluster hosting the specified index.

If the endpoint argument begins with a forward slash (/) the request is executed at the root of the Elasticsearch cluster. Otherwise, the request is executed relative to the specified index.

For example, this returns the Elasticsearch cluster information:

SELECT zdb.request('idxproducts', '/');
                            request                             
----------------------------------------------------------------
 {                                                             +
   "name" : "emac16.lan",                                      +
   "cluster_name" : "elasticsearch",                           +
   "cluster_uuid" : "HPxSF2doQy-KHFfFKFPEZQ",                  +
   "version" : {                                               +
     "number" : "7.9.0",                                       +
     "build_flavor" : "default",                               +
     "build_type" : "tar",                                     +
     "build_hash" : "a479a2a7fce0389512d6a9361301708b92dff667",+
     "build_date" : "2020-08-11T21:36:48.204330Z",             +
     "build_snapshot" : false,                                 +
     "lucene_version" : "8.6.0",                               +
     "minimum_wire_compatibility_version" : "6.8.0",           +
     "minimum_index_compatibility_version" : "6.0.0-beta1"     +
   },                                                          +
   "tagline" : "You Know, for Search"                          +
 }                                                             +
 
(1 row)

Whereas this returns the settings for the specified index:

 SELECT zdb.request('idxproducts', '_settings');
                                    request                                    
-------------------------------------------------------------------------------
 {                                                                            +
     "19524866.2200.19540060.19540070-882296036": {                           +
         "settings": {                                                        +
             "index": {                                                       +
                 "uuid": "Nw8D3ymUT9mbTCLTgBgMLA",                            +
                 "query": {                                                   +
                     "default_field": "zdb_all"                               +
                 },                                                           +
                 "version": {                                                 +
                     "created": "5060499"                                     +
                 },                                                           +
                 "analysis": {                                                +
                     "filter": {                                              +
...

FUNCTION profile_query(index regclass, query zdbquery) RETURNS json

Uses Elasticsearch's Profile API to provide detailed timing and execution information about a query.


FUNCTION zdb.determine_index(relation regclass) RETURNS regclass

Given a relation oid (either an actual index, a table, or a view) return the USING zombodb index that will be used when querying that relation.

If no index can be determined, NULL is returned.


FUNCTION zdb.index_name(index regclass) RETURNS text

Returns the ZomboDB-generated Elasticsearch index name for the specified Postgres index.

Example:

SELECT zdb.index_name('idxproducts');
                index_name                 
-------------------------------------------
 19524866.2200.19540060.19540070-882296036
(1 row)

FUNCTION zdb.index_url(index regclass) RETURNS text

Returns the url to the Elasticsearch cluster which contains the specified Postgres index.

Example:

SELECT zdb.index_url('idxproducts');
       index_url        
------------------------
 http://localhost:9200/

FUNCTION zdb.index_type_name(index regclass) RETURNS text

Returns the Elasticsearch index type name being used. Unless explicitly set during CREATE INDEX this will always return the string doc.

Example:

SELECT zdb.index_type_name('idxproducts');
 index_type_name 
-----------------
 doc
(1 row)

FUNCTION zdb.index_field_lists(index_relation regclass) RETURNS TABLE ("fieldname" text, "fields" text[])

Returns a resultset describing all the field lists that are defined for the specified index.

Example:

SELECT * FROM zdb_get_index_field_lists('idxsome_index');
    fieldname     |           fields
------------------+----------------------------
 title_and_author | {title,author}
 hashes           | {sha1,md5}
(2 rows)

FUNCTION zdb.reapply_mapping(index regclass) RETURNS bool

If you make a manual change to one of the underlying type mapping definitions (or related analyzer definition) in, for example, the zdb.type_mappings table, you can use this function to push those changes out to Elasticsearch for a specific index.

If for some reason the overall mapping change is not compatible with the index's existing mapping you'll need to instead issue a REINDEX INDEX command.


FUNCTION zdb.index_mapping(index regclass) RETURNS jsonb

Returns the full Elasticsearch mapping that ZomboDB generated for the specified Postgres index. This can be useful for ensuring your custom analyzers and field mappings are properly defined.

Example:

SELECT * FROM zdb.index_mapping('idxproducts');
                                                      index_mapping                                                       
--------------------------------------------------------------------------------------------------------------------------
 {                                                                                                                       +
         "mappings": {                                                                                                   +
             "doc": {                                                                                                    +
                 "_all": {                                                                                               +
                     "enabled": false                                                                                    +
                 },                                                                                                      +
                 "properties": {                                                                                         +
                     "id": {                                                                                             +
                         "type": "long"                                                                                  +
                     },                                                                                                  +
                     "name": {                                                                                           +
                         "type": "text",                                                                                 +
                         "copy_to": [                                                                                    +
                             "zdb_all"                                                                                   +
                         ],                                                                                              +
                         "analyzer": "zdb_standard",                                                                     +
                         "fielddata": true                                                                               +
                     },                                                                                                  +
                     "price": {                                                                                          +
                         "type": "long"                                                                                  +
                     },                                                                                                  +
                     "zdb_all": {                                                                                        +
                         "type": "text",                                                                                 +
                         "analyzer": "zdb_all_analyzer"                                                                  +
                     },                                                                                                  +
                     "keywords": {                                                                                       +
                         "type": "keyword",                                                                              +
                         "copy_to": [                                                                                    +
                             "zdb_all"                                                                                   +
                         ],                                                                                              +
                         "normalizer": "lowercase",                                                                      +
                         "ignore_above": 10922                                                                           +
                     },                                                                                                  +
                     "zdb_cmax": {                                                                                       +
                         "type": "integer"                                                                               +
                     },                                                                                                  +
                     "zdb_cmin": {                                                                                       +
                         "type": "integer"                                                                               +
                     },                                                                                                  +
                     "zdb_ctid": {                                                                                       +
                         "type": "long"                                                                                  +
                     },                                                                                                  +
                     "zdb_xmax": {                                                                                       +
                         "type": "long"                                                                                  +
                     },                                                                                                  +
                     "zdb_xmin": {                                                                                       +
                         "type": "long"                                                                                  +
                     },                                                                                                  +
                     "discontinued": {                                                                                   +
                         "type": "boolean"                                                                               +
                     },                                                                                                  +
                     "short_summary": {                                                                                  +
                         "type": "text",                                                                                 +
                         "copy_to": [                                                                                    +
                             "zdb_all"                                                                                   +
                         ],                                                                                              +
                         "analyzer": "zdb_standard",                                                                     +
                         "fielddata": true                                                                               +
                     },                                                                                                  +
                     "inventory_count": {                                                                                +
                         "type": "integer"                                                                               +
                     },                                                                                                  +
                     "long_description": {                                                                               +
                         "type": "text",                                                                                 +
                         "copy_to": [                                                                                    +
                             "zdb_all"                                                                                   +
                         ],                                                                                              +
                         "analyzer": "zdb_standard"                                                                      +
                     },                                                                                                  +
                     "zdb_aborted_xids": {                                                                               +
                         "type": "long"                                                                                  +
                     },                                                                                                  +
                     "availability_date": {                                                                              +
                         "type": "date",                                                                                 +
                         "copy_to": [                                                                                    +
                             "zdb_all"                                                                                   +
                         ]                                                                                               +
                     }                                                                                                   +
                 },                                                                                                      +
                 "dynamic_templates": [                                                                                  +
                     {                                                                                                   +
                         "strings": {                                                                                    +
                             "mapping": {                                                                                +
                                 "type": "keyword",                                                                      +
                                 "copy_to": "zdb_all",                                                                   +
                                 "normalizer": "lowercase",                                                              +
                                 "ignore_above": 10922                                                                   +
                             },                                                                                          +
                             "match_mapping_type": "string"                                                              +
                         }                                                                                               +
                     },                                                                                                  +
                     {                                                                                                   +
                         "dates_times": {                                                                                +
                             "mapping": {                                                                                +
                                 "type": "date",                                                                         +
                                 "format": "strict_date_optional_time||epoch_millis||HH:mm:ss.SSSSSS||HH:mm:ss.SSSSSSZZ",+
                                 "copy_to": "zdb_all"                                                                    +
                             },                                                                                          +
                             "match_mapping_type": "date"                                                                +
                         }                                                                                               +
                     }                                                                                                   +
                 ]                                                                                                       +
             }                                                                                                           +
         }                                                                                                               +
     }
(1 row)

FUNCTION zdb.field_mapping(index_relation regclass, field_name text) RETURNS json

Returns the Elasticsearch field mapping definition for the specified field. In the event the specified index has index links defined this will traverse those links to find the specified field.

Example:

select zdb.field_mapping('idxevents', 'event_type');
                                         field_mapping                                         
-----------------------------------------------------------------------------------------------
 {"type": "keyword", "copy_to": ["zdb_all"], "normalizer": "lowercase", "ignore_above": 10922}
(1 row)