X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=doc%2Fquerymodel.xml;h=f5d69338b0addb553360fc6949b9b50d7c17565c;hp=6c12214e2c9a7b6f948f2512a6f8db10b1a66601;hb=c3ff843e467932c6027a8b3b2ebda7b44612447e;hpb=3792780712898860435acfb9bf38c00f98cee037 diff --git a/doc/querymodel.xml b/doc/querymodel.xml index 6c12214..f5d6933 100644 --- a/doc/querymodel.xml +++ b/doc/querymodel.xml @@ -1,123 +1,122 @@ - Query Model - +
- Query Model Overview - + Query Model Overview +
Query Languages - + - Zebra is born as a networking Information Retrieval engine adhering - to the international standards - Z39.50 and - SRU, - and implement the - type-1 Reverse Polish Notation (RPN) query + &zebra; is born as a networking Information Retrieval engine adhering + to the international standards + &acro.z3950; and + &acro.sru;, + and implement the + type-1 Reverse Polish Notation (&acro.rpn;) query model defined there. Unfortunately, this model has only defined a binary encoded representation, which is used as transport packaging in - the Z39.50 protocol layer. This representation is not human - readable, nor defines any convenient way to specify queries. + the &acro.z3950; protocol layer. This representation is not human + readable, nor defines any convenient way to specify queries. - Since the type-1 (RPN) + Since the type-1 (&acro.rpn;) query structure has no direct, useful string representation, every client application needs to provide some form of mapping from a local query notation or representation to it. - - + +
- Prefix Query Format (PQF) + Prefix Query Format (&acro.pqf;) - Index Data has defined a textual representation in the + Index Data has defined a textual representation in the Prefix Query Format, short - PQF, which maps - one-to-one to binary encoded - type-1 RPN queries. - PQF has been adopted by other - parties developing Z39.50 software, and is often referred to as - Prefix Query Notation, or in short - PQN. See + &acro.pqf;, which maps + one-to-one to binary encoded + type-1 &acro.rpn; queries. + &acro.pqf; has been adopted by other + parties developing &acro.z3950; software, and is often referred to as + Prefix Query Notation, or in short + &acro.pqn;. See for further explanations and - descriptions of Zebra's capabilities. + descriptions of &zebra;'s capabilities. -
- +
+
- Common Query Language (CQL) + Common Query Language (&acro.cql;) - The query model of the type-1 RPN, - expressed in PQF/PQN is natively supported. - On the other hand, the default SRU + The query model of the type-1 &acro.rpn;, + expressed in &acro.pqf;/&acro.pqn; is natively supported. + On the other hand, the default &acro.sru; web services Common Query Language - CQL is not natively supported. + &acro.cql; is not natively supported. - Zebra can be configured to understand and map CQL to PQF. See + &zebra; can be configured to understand and map &acro.cql; to &acro.pqf;. See . -
- +
+
Operation types - Zebra supports all of the three different - Z39.50/SRU operations defined in the - standards: explain, search, + &zebra; supports all of the three different + &acro.z3950;/&acro.sru; operations defined in the + standards: explain, search, and scan. A short description of the - functionality and purpose of each is quite in order here. + functionality and purpose of each is quite in order here.
Explain Operation - The syntax of Z39.50/SRU queries is + The syntax of &acro.z3950;/&acro.sru; queries is well known to any client, but the specific semantics - taking into account a particular servers functionalities and abilities - must be - discovered from case to case. Enters the - explain operation, which provides the means for learning which + discovered from case to case. Enters the + explain operation, which provides the means for learning which fields (also called indexes or access points) are provided, which default parameter the server uses, which retrieve document formats are defined, and which specific parts - of the general query model are supported. + of the general query model are supported. - The Z39.50 embeds the explain operation - by performing a - search in the magic + The &acro.z3950; embeds the explain operation + by performing a + search in the magic IR-Explain-1 database; - see . + see . - In SRU, explain is an entirely separate - operation, which returns an ZeeRex XML record according to the + In &acro.sru;, explain is an entirely separate + operation, which returns an ZeeRex &acro.xml; record according to the structure defined by the protocol. In both cases, the information gathered through explain operations can be used to auto-configure a client user interface to the servers - capabilities. + capabilities.
@@ -125,7 +124,7 @@ Scan Operation The scan operation is a helper functionality, - which operates on one index or access point a time. + which operates on one index or access point a time. It provides @@ -134,62 +133,61 @@ the indexes, and in addition the scan operation returns the number of documents indexed by each term. A search client can use this information to propose proper - spelling of search terms, to auto-fill search boxes, or to + spelling of search terms, to auto-fill search boxes, or to display controlled vocabularies.
- + -
- RPN queries and semantics + &acro.rpn; queries and semantics - The PQF grammar - is documented in the YAZ manual, and shall not be - repeated here. This textual PQF representation - is not transmistted to Zebra during search, but it is in the - client mapped to the equivalent Z39.50 binary - query parse tree. + The &acro.pqf; grammar + is documented in the &yaz; manual, and shall not be + repeated here. This textual &acro.pqf; representation + is not transmitted to &zebra; during search, but it is in the + client mapped to the equivalent &acro.z3950; binary + query parse tree. - +
- RPN tree structure + &acro.rpn; tree structure - The RPN parse tree - or the equivalent textual representation in PQF - - may start with one specification of the + The &acro.rpn; parse tree - or the equivalent textual representation in &acro.pqf; - + may start with one specification of the attribute set used. Following is a query - tree, which - consists of atomic query parts (APT) or + tree, which + consists of atomic query parts (&acro.apt;) or named result sets, eventually - paired by boolean binary operators, and - finally recursively combined into - complex query trees. + paired by boolean binary operators, and + finally recursively combined into + complex query trees. - +
Attribute sets Attribute sets define the exact meaning and semantics of queries - issued. Zebra comes with some predefined attribute set + issued. &zebra; comes with some predefined attribute set definitions, others can easily be defined and added to the configuration. - + - Attribute sets predefined in Zebra + Attribute sets predefined in &zebra; Attribute set - PQF notation (Short hand) + &acro.pqf; notation (Short hand) Status Notes - + Explain @@ -201,51 +199,42 @@ predefined - Bib-1 + &acro.bib1; bib-1 - Standard PQF query language attribute set which defines the - semantics of Z39.50 searching. In addition, all of the - non-use attributes (types 2-11) define the hard-wired - Zebra internal query + Standard &acro.pqf; query language attribute set which defines the + semantics of &acro.z3950; searching. In addition, all of the + non-use attributes (types 2-14) define the hard-wired + &zebra; internal query processing. default GILS gils - Extension to the Bib-1 attribute set. + Extension to the &acro.bib1; attribute set. predefined -
- + The use attributes (type 1) mappings the predefined attribute sets are found in the - attribute set configuration files tab/*.att. + attribute set configuration files tab/*.att. - + - The Zebra internal query processing is modeled after - the Bib-1 attribute set, and the non-use + The &zebra; internal query processing is modeled after + the &acro.bib1; attribute set, and the non-use attributes type 2-6 are hard-wired in. It is therefore essential - to be familiar with . + to be familiar with . - +
- +
Boolean operators @@ -253,7 +242,7 @@ using the standard boolean operators into new query trees. Thus, boolean operators are always internal nodes in the query tree. - + Boolean operators @@ -279,24 +268,24 @@ @prox binary PROXIMITY operator - Set intersection of two atomic queries hit sets. In - addition, the intersection set is purged for all - documents which do not satisfy the requested query - term proximity. Usually a proper subset of the AND + Set intersection of two atomic queries hit sets. In + addition, the intersection set is purged for all + documents which do not satisfy the requested query + term proximity. Usually a proper subset of the AND operation.
- + - For example, we can combine the terms - information and retrieval + For example, we can combine the terms + information and retrieval into different searches in the default index of the default attribute set as follows. Querying for the union of all documents containing the terms information OR - retrieval: + retrieval: Z> find @or information retrieval @@ -304,7 +293,7 @@ Querying for the intersection of all documents containing the terms information AND - retrieval: + retrieval: The hit set is a subset of the corresponding OR query. @@ -316,8 +305,8 @@ terms information AND retrieval, taking proximity into account: The hit set is a subset of the corresponding - AND query - (see the PQF grammar for + AND query + (see the &acro.pqf; grammar for details on the proximity operator): Z> find @prox 0 3 0 2 k 2 information retrieval @@ -327,7 +316,7 @@ Querying for the intersection of all documents containing the terms information AND retrieval, in the same order and near each - other as described in the term list. + other as described in the term list. The hit set is a subset of the corresponding PROXIMITY query. @@ -335,26 +324,26 @@
- - + +
- Atomic queries (APT) + Atomic queries (&acro.apt;) Atomic queries are the query parts which work on one access point only. These consist of an attribute list followed by a single term or a - quoted term list, and are often called - Attributes-Plus-Terms (APT) queries. + quoted term list, and are often called + Attributes-Plus-Terms (&acro.apt;) queries. - Atomic (APT) queries are always leaf nodes in the PQF query tree. - UN-supplied non-use attributes types 2-11 are either inherited from - higher nodes in the query tree, or are set to Zebra's default values. - See for details. + Atomic (&acro.apt;) queries are always leaf nodes in the &acro.pqf; query tree. + UN-supplied non-use attributes types 2-12 are either inherited from + higher nodes in the query tree, or are set to &zebra;'s default values. + See for details. - + - Atomic queries (APT) + Atomic queries (&acro.apt;) @@ -362,19 +351,19 @@ Type Notes - + attribute list List of orthogonal attributes Any of the orthogonal attribute types may be omitted, these are inherited from higher query tree nodes, or if not - inherited, are set to the default Zebra configuration values. + inherited, are set to the default &zebra; configuration values. term - single term + single term or quoted term list Here the search terms or list of search terms is added to the query @@ -406,15 +395,15 @@ - The scan operation is only supported with - atomic APT queries, as it is bound to one access point at a + The scan operation is only supported with + atomic &acro.apt; queries, as it is bound to one access point at a time. Boolean query trees are not allowed during scan. - - + + For example, we might want to scan the title index, starting with - the term + the term debussy, and displaying this and the following terms in lexicographic order: @@ -422,17 +411,17 @@ - - + +
Named Result Sets - Named result sets are supported in Zebra, and result sets can be + Named result sets are supported in &zebra;, and result sets can be used as operands without limitations. It follows that named - result sets are leaf nodes in the PQF query tree, exactly as - atomic APT queries are. + result sets are leaf nodes in the &acro.pqf; query tree, exactly as + atomic &acro.apt; queries are. - + After the execution of a search, the result set is available at the server, such that the client can use it for subsequent searches or retrieval requests. The Z30.50 standard actually @@ -441,12 +430,12 @@ send a diagnostic to the effect that the requested result set does not exist any more. - + Defining a named result set and re-using it in the next query, using yaz-client. Notice that the client, not the server, assigns the string '1' to the - named result set. + named result set. Z> f @attr 1=4 mozart ... @@ -457,33 +446,33 @@ Number of hits: 14, setno 2 - + - Named result sets are only supported by the Z39.50 protocol. - The SRU web service is stateless, and therefore the notion of - named result sets does not exist when accessing a Zebra server by - the SRU protocol. + Named result sets are only supported by the &acro.z3950; protocol. + The &acro.sru; web service is stateless, and therefore the notion of + named result sets does not exist when accessing a &zebra; server by + the &acro.sru; protocol.
- +
- Zebra's special access point of type 'string' + &zebra;'s special access point of type 'string' - The numeric use (type 1) attribute is usually + The numeric use (type 1) attribute is usually referred to from a given - attribute set. In addition, Zebra let you use + attribute set. In addition, &zebra; let you use any internal index - name defined in your configuration + name defined in your configuration as use attribute value. This is a great feature for debugging, and when you do not need the complexity of defined use attribute values. It is - the preferred way of accessing Zebra indexes directly. + the preferred way of accessing &zebra; indexes directly. Finding all documents which have the term list "information - retrieval" in an Zebra index, using it's internal full string + retrieval" in an &zebra; index, using its internal full string name. Scanning the same index. Z> find @attr 1=sometext "information retrieval" @@ -492,7 +481,7 @@ Searching or scanning - the bib-1 use attribute 54 using it's string name: + the bib-1 use attribute 54 using its string name: Z> find @attr 1=Code-language eng Z> scan @attr 1=Code-language "" @@ -501,7 +490,7 @@ It is possible to search in any silly string index - if it's defined in your - indexation rules and can be parsed by the PQF parser. + indexing rules and can be parsed by the &acro.pqf; parser. This is definitely not the recommended use of this facility, as it might confuse your users with some very unexpected results. @@ -510,57 +499,57 @@ - See also for details, and + See also for details, and - for the SRU PQF query extension using string names as a fast + for the &acro.sru; &acro.pqf; query extension using string names as a fast debugging facility.
- +
- Zebra's special access point of type 'XPath' - for GRS filters + &zebra;'s special access point of type 'XPath' + for &acro.grs1; filters As we have seen above, it is possible (albeit seldom a great - idea) to emulate + idea) to emulate XPath 1.0 based search by defining use (type 1) - string attributes which in appearance + string attributes which in appearance resemble XPath queries. There are two problems with this approach: first, the XPath-look-alike has to - be defined at indexation time, no new undefined + be defined at indexing time, no new undefined XPath queries can entered at search time, and second, it might confuse users very much that an XPath-alike index name in fact - gets populated from a possible entirely different XML element - than it pretends to access. + gets populated from a possible entirely different &acro.xml; element + than it pretends to access. - When using the GRS Record Model + When using the &acro.grs1; Record Model (see ), we have the - possibility to embed life + possibility to embed life XPath expressions - in the PQF queries, which are here called + in the &acro.pqf; queries, which are here called use (type 1) xpath - attributes. You must enable the - xpath enable directive in your - .abs configuration files. + attributes. You must enable the + xpath enable directive in your + .abs configuration files. - Only a very restricted subset of the - XPath 1.0 - standard is supported as the GRS record model is simpler than - a full XML DOM structure. See the following examples for + Only a very restricted subset of the + XPath 1.0 + standard is supported as the &acro.grs1; record model is simpler than + a full &acro.xml; &acro.dom; structure. See the following examples for possibilities. - Finding all documents which have the term "content" - inside a text node found in a specific XML DOM - subtree, whose starting element is - addressed by XPath. + Finding all documents which have the term "content" + inside a text node found in a specific &acro.xml; &acro.dom; + subtree, whose starting element is + addressed by XPath. - Z> find @attr 1=/root content + Z> find @attr 1=/root content Z> find @attr 1=/root/first content Notice that the @@ -571,22 +560,22 @@ It follows that the above searches are interpreted as: - Z> find @attr 1=/root//text() content + Z> find @attr 1=/root//text() content Z> find @attr 1=/root/first//text() content - + Searching inside attribute strings is possible: - Z> find @attr 1=/link/@creator morten + Z> find @attr 1=/link/@creator morten - + - + Filter the addressing XPath by a predicate working on exact string values in - attributes (in the XML sense) can be done: return all those docs which + attributes (in the &acro.xml; sense) can be done: return all those docs which have the term "english" contained in one of all text sub nodes of the subtree defined by the XPath /record/title[@lang='en']. And similar @@ -594,21 +583,21 @@ Z> find @attr 1=/record/title[@lang='en'] english Z> find @attr 1=/link[@creator='sisse'] sibelius - Z> find @attr 1=/link[@creator='sisse']/description[@xml:lang='da'] sibelius + Z> find @attr 1=/link[@creator='sisse']/description[@xml:lang='da'] sibelius - - - Combining numeric indexes, boolean expressions, + + + Combining numeric indexes, boolean expressions, and xpath based searches is possible: Z> find @attr 1=/record/title @and foo bar Z> find @and @attr 1=/record/title foo @attr 1=4 bar - + - Escaping PQF keywords and other non-parseable XPath constructs - with '{ }' to prevent client-side PQF parsing + Escaping &acro.pqf; keywords and other non-parseable XPath constructs + with '{ }' to prevent client-side &acro.pqf; parsing syntax errors: Z> find @attr {1=/root/first[@attr='danish']} content @@ -626,39 +615,39 @@
- +
Explain Attribute Set - The Z39.50 standard defines the + The &acro.z3950; standard defines the Explain attribute set - Exp-1, which is used to discover information + Exp-1, which is used to discover information about a server's search semantics and functional capabilities - Zebra exposes a "classic" + &zebra; exposes a "classic" Explain database by base name IR-Explain-1, which - is populated with system internal information. + is populated with system internal information. - - The attribute-set exp-1 consists of a single - use attribute (type 1). + + The attribute-set exp-1 consists of a single + use attribute (type 1). In addition, the non-Use - Bib-1 attributes, that is, the types + &acro.bib1; attributes, that is, the types Relation, Position, - Structure, Truncation, - and Completeness are imported from - the Bib-1 attribute set, and may be used - within any explain query. + Structure, Truncation, + and Completeness are imported from + the &acro.bib1; attribute set, and may be used + within any explain query. - +
- Use Attributes (type = 1) + Use Attributes (type = 1) The following Explain search attributes are supported: - ExplainCategory (@attr 1=1), - DatabaseName (@attr 1=3), - DateAdded (@attr 1=9), + ExplainCategory (@attr 1=1), + DatabaseName (@attr 1=3), + DateAdded (@attr 1=9), DateChanged(@attr 1=10). @@ -668,26 +657,26 @@ DatabaseInfo, AttributeDetails. - See tab/explain.att and the - Z39.50 standard + See tab/explain.att and the + &acro.z3950; standard for more information.
- +
Explain searches with yaz-client Classic Explain only defines retrieval of Explain information - via ASN.1. Practically no Z39.50 clients supports this. Fortunately - they don't have to - Zebra allows retrieval of this information + via ASN.1. Practically no &acro.z3950; clients supports this. Fortunately + they don't have to - &zebra; allows retrieval of this information in other formats: - SUTRS, XML, - GRS-1 and ASN.1 Explain. + &acro.sutrs;, &acro.xml;, + &acro.grs1; and ASN.1 Explain. - + List supported categories to find out which explain commands are - supported: + supported: Z> base IR-Explain-1 Z> find @attr exp1 1=1 categorylist @@ -695,7 +684,7 @@ Z> show 1+2 - + Get target info, that is, investigate which databases exist at this server endpoint: @@ -710,7 +699,7 @@ Z> show 1+1 - + List all supported databases, the number of hits is the number of databases found, which most commonly are the @@ -724,7 +713,7 @@ Z> show 1+2 - + Get database info record for database Default. @@ -737,13 +726,13 @@ Z> find @attrset exp1 @and @attr 1=1 databaseinfo @attr 1=3 Default - + Get attribute details record for database Default. - This query is very useful to study the internal Zebra indexes. + This query is very useful to study the internal &zebra; indexes. If records have been indexed using the alvis - XSLT filter, the string representation names of the known indexes can be + &acro.xslt; filter, the string representation names of the known indexes can be found. Z> base IR-Explain-1 @@ -756,39 +745,39 @@
- +
- +
- Bib-1 Attribute Set + &acro.bib1; Attribute Set Most of the information contained in this section is an excerpt of - the ATTRIBUTE SET BIB-1 (Z39.50-1995) SEMANTICS - found at . The Bib-1 - Attribute Set Semantics from 1995, also in an updated - Bib-1 - Attribute Set + the ATTRIBUTE SET &acro.bib1; (&acro.z3950;-1995) SEMANTICS + found at . The &acro.bib1; + Attribute Set Semantics from 1995, also in an updated + &acro.bib1; + Attribute Set version from 2003. Index Data is not the copyright holder of this information, except for the configuration details, the listing of - Zebra's capabilities, and the example queries. + &zebra;'s capabilities, and the example queries. - - -
+ + +
Use Attributes (type 1) - - A use attribute specifies an access point for any atomic query. - These access points are highly dependent on the attribute set used - in the query, and are user configurable using the following - default configuration files: - tab/bib1.att, - tab/dan1.att, - tab/explain.att, and - tab/gils.att. + + A use attribute specifies an access point for any atomic query. + These access points are highly dependent on the attribute set used + in the query, and are user configurable using the following + default configuration files: + tab/bib1.att, + tab/dan1.att, + tab/explain.att, and + tab/gils.att. - - For example, some few Bib-1 use + + For example, some few &acro.bib1; use attributes from the tab/bib1.att are: att 1 Personal-name @@ -808,44 +797,44 @@ att 1036 Author-Title-Subject - - New attribute sets can be added by adding new - tab/*.att configuration files, which need to - be sourced in the main configuration zebra.cfg. + + New attribute sets can be added by adding new + tab/*.att configuration files, which need to + be sourced in the main configuration zebra.cfg. + + + In addition, &zebra; allows the access of + internal index names and dynamic + XPath as use attributes; see + and + . - - In addition, Zebra allows the access of - internal index names and dynamic - XPath as use attributes; see - and - . - - - Phrase search for information retrieval in - the title-register, scanning the same register afterwards: - - Z> find @attr 1=4 "information retrieval" - Z> scan @attr 1=4 information - - + + Phrase search for information retrieval in + the title-register, scanning the same register afterwards: + + Z> find @attr 1=4 "information retrieval" + Z> scan @attr 1=4 information + +
- Zebra general Bib1 Non-Use Attributes (type 2-6) - + &zebra; general Bib1 Non-Use Attributes (type 2-6) +
Relation Attributes (type 2) - + Relation attributes describe the relationship of the access - point (left side + point (left side of the relation) to the search term as qualified by the attributes (right side of the relation), e.g., Date-publication <= 1975. - +
Relation Attributes (type 2) @@ -916,15 +905,15 @@ AlwaysMatches searches are only supported if alwaysmatches indexing has been enabled. See - - + + The relation attributes 1-5 are supported and work exactly as expected. - All ordering operations are based on a lexicographical ordering, - expect when the + All ordering operations are based on a lexicographical ordering, + except when the structure attribute numeric (109) is used. In - this case, ordering is numerical. See + this case, ordering is numerical. See . Z> find @attr 1=Title @attr 2=1 music @@ -950,11 +939,11 @@ - The relation attribute + The relation attribute Relevance (102) is supported, see for full information. - + Ranked search for information retrieval in the title-register: @@ -964,22 +953,22 @@ - The relation attribute + The relation attribute AlwaysMatches (103) is in the default configuration - supported in conjecture with structure attribute + supported in conjecture with structure attribute Phrase (1) (which may be omitted by - default). + default). It can be configured to work with other structure attributes, - see the configuration file - tab/default.idx and - . + see the configuration file + tab/default.idx and + . AlwaysMatches (103) is a great way to discover how many documents have been indexed in a given field. The search term is ignored, but needed for correct - PQF syntax. An empty search term may be supplied. + &acro.pqf; syntax. An empty search term may be supplied. Z> find @attr 1=Title @attr 2=103 "" Z> find @attr 1=Title @attr 2=103 @attr 4=1 "" @@ -991,7 +980,7 @@
Position Attributes (type 3) - + The position attribute specifies the location of the search term within the field or subfield in which it appears. @@ -1029,32 +1018,31 @@ - Zebra only supports first-in-field seaches if the + &zebra; only supports first-in-field seaches if the firstinfield is enabled for the index Refer to . - Zebra does not distinguish between first in field and + &zebra; does not distinguish between first in field and first in subfield. They result in the same hit count. - Searching for first position in (sub)field in only supported in Zebra + Searching for first position in (sub)field in only supported in &zebra; 2.0.2 and later.
- +
Structure Attributes (type 4) - + The structure attribute specifies the type of search term. This causes the search to be mapped on - different Zebra internal indexes, which must have been defined - at index time. + different &zebra; internal indexes, which must have been defined + at index time. - - The possible values of the + + The possible values of the structure attribute (type 4) can be defined - using the configuration file - tab/default.idx. + using the configuration file tab/default.idx. The default configuration is summarized in this table. @@ -1152,74 +1140,74 @@
- - - The structure attribute values - Word list (6) - is supported, and maps to the boolean AND - combination of words supplied. The word list is useful when - google-like bag-of-word queries need to be translated from a GUI - query language to PQF. For example, the following queries - are equivalent: - - Z> find @attr 1=Title @attr 4=6 "mozart amadeus" - Z> find @attr 1=Title @and mozart amadeus - - + + The structure attribute values + Word list (6) + is supported, and maps to the boolean AND + combination of words supplied. The word list is useful when + Google-like bag-of-word queries need to be translated from a GUI + query language to &acro.pqf;. For example, the following queries + are equivalent: + + Z> find @attr 1=Title @attr 4=6 "mozart amadeus" + Z> find @attr 1=Title @and mozart amadeus + + - - The structure attribute value - Free-form-text (105) and - Document-text (106) - are supported, and map both to the boolean OR - combination of words supplied. The following queries - are equivalent: - - Z> find @attr 1=Body-of-text @attr 4=105 "bach salieri teleman" - Z> find @attr 1=Body-of-text @attr 4=106 "bach salieri teleman" - Z> find @attr 1=Body-of-text @or bach @or salieri teleman - - This OR list of terms is very useful in - combination with relevance ranking: - - Z> find @attr 1=Body-of-text @attr 2=102 @attr 4=105 "bach salieri teleman" - - - - - The structure attribute value - Local number (107) - is supported, and maps always to the Zebra internal document ID, - irrespectively which use attribute is specified. The following queries - have exactly the same unique record in the hit set: - - Z> find @attr 4=107 10 - Z> find @attr 1=4 @attr 4=107 10 - Z> find @attr 1=1010 @attr 4=107 10 - - + + The structure attribute value + Free-form-text (105) and + Document-text (106) + are supported, and map both to the boolean OR + combination of words supplied. The following queries + are equivalent: + + Z> find @attr 1=Body-of-text @attr 4=105 "bach salieri teleman" + Z> find @attr 1=Body-of-text @attr 4=106 "bach salieri teleman" + Z> find @attr 1=Body-of-text @or bach @or salieri teleman + + This OR list of terms is very useful in + combination with relevance ranking: + + Z> find @attr 1=Body-of-text @attr 2=102 @attr 4=105 "bach salieri teleman" + + - - In - the GILS schema (gils.abs), the - west-bounding-coordinate is indexed as type n, - and is therefore searched by specifying - structure=Numeric String. - To match all those records with west-bounding-coordinate greater - than -114 we use the following query: - - Z> find @attr 4=109 @attr 2=5 @attr gils 1=2038 -114 - + + The structure attribute value + Local number (107) + is supported, and maps always to the &zebra; internal document ID, + irrespectively which use attribute is specified. The following queries + have exactly the same unique record in the hit set: + + Z> find @attr 4=107 10 + Z> find @attr 1=4 @attr 4=107 10 + Z> find @attr 1=1010 @attr 4=107 10 + + + + + In + the GILS schema (gils.abs), the + west-bounding-coordinate is indexed as type n, + and is therefore searched by specifying + structure=Numeric String. + To match all those records with west-bounding-coordinate greater + than -114 we use the following query: + + Z> find @attr 4=109 @attr 2=5 @attr gils 1=2038 -114 + - The exact mapping between PQF queries and Zebra internal indexes - and index types is explained in + The exact mapping between &acro.pqf; queries and &zebra; internal indexes + and index types is explained in .
- + +
Truncation Attributes (type = 5) @@ -1301,10 +1289,10 @@ ... Number of hits: 95, setno 8 - + - The truncation attribute value + The truncation attribute value Process # in search term (101) is a poor-man's regular expression search. It maps each # to .*, and @@ -1317,10 +1305,10 @@ Number of hits: 89, setno 10 - + - The truncation attribute value - Regexp-1 (102) is a normal regular search, + The truncation attribute value + Regexp-1 (102) is a normal regular search, see for details. Z> find @attr 1=Body-of-text @attr 5=102 schnit+ke @@ -1329,13 +1317,13 @@ - The truncation attribute value - Regexp-2 (103) is a Zebra specific extension + The truncation attribute value + Regexp-2 (103) is a &zebra; specific extension which allows fuzzy matches. One single error in spelling of search terms is allowed, i.e., a document is hit if it includes a term which can be mapped to the used search term by one character substitution, addition, deletion or - change of position. + change of position. Z> find @attr 1=Body-of-text @attr 5=100 schnittke ... @@ -1346,21 +1334,21 @@ Number of hits: 103, setno 15 ... - +
- +
- Completeness Attributes (type = 6) + Completeness Attributes (type = 6) The Completeness Attributes (type = 6) - is used to specify that a given search term or term list is either - part of the terms of a given index/field + is used to specify that a given search term or term list is either + part of the terms of a given index/field (Incomplete subfield (1)), or is what literally is found in the entire field's index (Complete field (3)). - + Completeness Attributes (type = 6) @@ -1396,59 +1384,59 @@ The Completeness Attributes (type = 6) is only partially and conditionally supported in the sense that it is ignored if the hit index is - not of structure type="w" or + not of structure type="w" or type="p". - + Incomplete subfield (1) is the default, and - makes Zebra use - register type="w", whereas + makes &zebra; use + register type="w", whereas Complete field (3) triggers search and scan in index type="p". - The Complete subfield (2) is a reminiscens - from the happy MARC - binary format days. Zebra does not support it, but maps silently + The Complete subfield (2) is a reminiscent + from the happy &acro.marc; + binary format days. &zebra; does not support it, but maps silently to Complete field (3). - The exact mapping between PQF queries and Zebra internal indexes - and index types is explained in + The exact mapping between &acro.pqf; queries and &zebra; internal indexes + and index types is explained in . - - + +
- Extended Zebra RPN Features + Extended &zebra; &acro.rpn; Features - The Zebra internal query engine has been extended to specific needs + The &zebra; internal query engine has been extended to specific needs not covered by the bib-1 attribute set query model. These extensions are non-standard and non-portable: most functional extensions are modeled over the bib-1 attribute set, - defining type 7-9 attributes. - There are also the special + defining type 7 and higher values. + There are also the special string type index names for the - idxpath attribute set. + idxpath attribute set. - +
- Zebra specific retrieval of all records + &zebra; specific retrieval of all records - Zebra defines a hardwired string index name + &zebra; defines a hardwired string index name called _ALLRECORDS. It matches any record - contained in the database, if used in conjunction with - the relation attribute + contained in the database, if used in conjunction with + the relation attribute AlwaysMatches (103). - + The _ALLRECORDS index name is used for total database export. The search term is ignored, it may be empty. @@ -1470,28 +1458,28 @@ The special string index _ALLRECORDS is experimental, and the provided functionality and syntax may very - well change in future releases of Zebra. + well change in future releases of &zebra;.
- Zebra Search Attribute Extensions + &zebra; Search Attribute Extensions - Name + Name Value Operation - Zebra version + &zebra; version @@ -1514,51 +1502,73 @@ 1.1 - Approx Limit - 11 + Term Reference + 10 search 1.4 - Term Reference - 10 + Local Approx Limit + 11 search 1.4 + + Global Approx Limit + 12 + search + 2.0.8 + + + Maximum number of truncated terms (truncmax) + 13 + search + 2.0.10 + + + + Specifies whether un-indexed fields should be ignored. + A zero value (default) throws a diagnostic when an un-indexed + field is specified. A non-zero value makes it return 0 hits. + + 14 + search + 2.0.16 + -
- + +
- Zebra Extension Embedded Sort Attribute (type 7) + &zebra; Extension Embedded Sort Attribute (type 7) The embedded sort is a way to specify sort within a query - thus removing the need to send a Sort Request separately. It is both faster and does not require clients to deal with the Sort - Facility. + Facility. - + - All ordering operations are based on a lexicographical ordering, - expect when the + All ordering operations are based on a lexicographical ordering, + except when the structure attribute numeric (109) is used. In - this case, ordering is numerical. See + this case, ordering is numerical. See . - + The possible values after attribute type 7 are - 1 ascending and - 2 descending. - The attributes+term (APT) node is separate from the - rest and must be @or'ed. - The term associated with APT is the sorting level in integers, - where 0 means primary sort, + 1 ascending and + 2 descending. + The attributes+term (&acro.apt;) node is separate from the + rest and must be @or'ed. + The term associated with &acro.apt; is the sorting level in integers, + where 0 means primary sort, 1 means secondary sort, and so forth. See also . - For example, searching for water, sort by title (ascending) + For example, searching for water, sort by title (ascending) Z> find @or @attr 1=1016 water @attr 7=1 @attr 1=4 0 @@ -1571,82 +1581,102 @@
- -
- Zebra Extension Rank Weight Attribute (type 9) + &zebra; Extension Rank Weight Attribute (type 9) Rank weight is a way to pass a value to a ranking algorithm - so - that one APT has one value - while another as a different one. + that one &acro.apt; has one value - while another as a different one. See also . For example, searching for utah in title with weight 30 as well - as any with weight 20: - + as any with weight 20: + Z> find @attr 2=102 @or @attr 9=30 @attr 1=4 utah @attr 9=20 utah -
- -
- Zebra Extension Approximative Limit Attribute (type 11) +
+ +
+ &zebra; Extension Term Reference Attribute (type 10) - Zebra computes - unless otherwise configured - - the exact hit count for every APT + &zebra; supports the searchResult-1 facility. + If the Term Reference Attribute (type 10) is + given, that specifies a subqueryId value returned as part of the + search result. It is a way for a client to name an &acro.apt; part of a + query. + + + + + Experimental. Do not use in production code. + + + +
+ + + +
+ Local Approximative Limit Attribute (type 11) + + &zebra; computes - unless otherwise configured - + the exact hit count for every &acro.apt; (leaf) in the query tree. These hit counts are returned as part of - the searchResult-1 facility in the binary encoded Z39.50 search + the searchResult-1 facility in the binary encoded &acro.z3950; search response packages. - By setting an estimation limit size of the resultset of the APT - leaves, Zebra stoppes processing the result set when the limit + By setting an estimation limit size of the resultset of the &acro.apt; + leaves, &zebra; stops processing the result set when the limit length is reached. Hit counts under this limit are still precise, but hit counts over it are estimated using the statistics gathered from the chopped result set. - Specifying a limit of 0 resuts in exact hit counts. + Specifying a limit of 0 results in exact hit counts. For example, we might be interested in exact hit count for a, but - for b we allow hit count estimates for 1000 and higher. + for b we allow hit count estimates for 1000 and higher. Z> find @and a @attr 11=1000 b @@ -1656,69 +1686,60 @@ The estimated hit count facility makes searches faster, as one only needs to process large hit lists partially. It is mostly used in huge databases, where you you want trade - exactness of hit counts against speed of execution. + exactness of hit counts against speed of execution. Do not use approximative hit count limits in conjunction with relevance ranking, as re-sorting of the - result set obviosly only works when the entire result set has - been processed. - - - - - This facility clashes with rank weight, because there all - documents in the hit lists need to be examined for scoring and - re-sorting. - It is an experimental - extension. Do not use in production code. + result set only works when the entire result set has + been processed.
-
- Zebra Extension Term Reference Attribute (type 10) +
+ Global Approximative Limit Attribute (type 12) - Zebra supports the searchResult-1 facility. - If the Term Reference Attribute (type 10) is - given, that specifies a subqueryId value returned as part of the - search result. It is a way for a client to name an APT part of a - query. + By default &zebra; computes precise hit counts for a query as + a whole. Setting attribute 12 makes it perform approximative + hit counts instead. It has the same semantics as + estimatehits for the . - + The attribute (12) can occur anywhere in the query tree. + Unlike regular attributes it does not relate to the leaf (&acro.apt;) + - but to the whole query. + - Experimental. Do not use in production code. - + Do not use approximative hit count limits + in conjunction with relevance ranking, as re-sorting of the + result set only works when the entire result set has + been processed. + -
+
-
- Zebra specific Scan Extensions to all Attribute Sets + &zebra; specific Scan Extensions to all Attribute Sets - Zebra extends the Bib1 attribute types, and these extensions are - recognized regardless of attribute + &zebra; extends the Bib1 attribute types, and these extensions are + recognized regardless of attribute set used in a scan operation query. - Zebra Scan Attribute Extensions + &zebra; Scan Attribute Extensions Name Type Operation - Zebra version + &zebra; version @@ -1730,52 +1751,52 @@ Approximative Limit - 9 + 12 scan - 1.4 + 2.0.20 -
- + +
- Zebra Extension Result Set Narrow (type 8) + &zebra; Extension Result Set Narrow (type 8) If attribute Result Set Narrow (type 8) is given for scan, the value is the name of a - result set. Each hit count in scan is - @and'ed with the result set given. + result set. Each hit count in scan is + @and'ed with the result set given. - Consider for example + Consider for example the case of scanning all title fields around the scanterm mozart, then refining the scan by issuing a filtering query for amadeus to - restrict the scan to the result set of the query: + restrict the scan to the result set of the query: - Z> scan @attr 1=4 mozart - ... - * mozart (43) - mozartforskningen (1) - mozartiana (1) - mozarts (16) - ... - Z> f @attr 1=4 amadeus - ... - Number of hits: 15, setno 2 - ... - Z> scan @attr 1=4 @attr 8=2 mozart - ... - * mozart (14) - mozartforskningen (0) - mozartiana (0) - mozarts (1) - ... + Z> scan @attr 1=4 mozart + ... + * mozart (43) + mozartforskningen (1) + mozartiana (1) + mozarts (16) + ... + Z> f @attr 1=4 amadeus + ... + Number of hits: 15, setno 2 + ... + Z> scan @attr 1=4 @attr 8=2 mozart + ... + * mozart (14) + mozartforskningen (0) + mozartiana (0) + mozarts (1) + ... - + - Zebra 2.0.2 and later is able to skip 0 hit counts. This, however, + &zebra; 2.0.2 and later is able to skip 0 hit counts. This, however, is known not to scale if the number of terms to skip is high. This most likely will happen if the result set is small (and result in many 0 hits). @@ -1783,42 +1804,42 @@
- Zebra Extension Approximative Limit (type 11) + &zebra; Extension Approximative Limit (type 12) - The Zebra Extension Approximative Limit (type 11) is a way to + The &zebra; Extension Approximative Limit (type 12) is a way to enable approximate hit counts for scan hit counts, in the same - way as for search hit counts. + way as for search hit counts.
- +
- Zebra special IDXPATH Attribute Set for GRS indexing + &zebra; special &acro.idxpath; Attribute Set for &acro.grs1; indexing - The attribute-set idxpath consists of a single - Use (type 1) attribute. All non-use attributes behave as normal. + The attribute-set idxpath consists of a single + Use (type 1) attribute. All non-use attributes behave as normal. This feature is enabled when defining the - xpath enable option in the GRS filter + xpath enable option in the &acro.grs1; filter *.abs configuration files. If one wants to use the special idxpath numeric attribute set, the - main Zebra configuration file zebra.cfg + main &zebra; configuration file zebra.cfg directive attset: idxpath.att must be enabled. The idxpath is deprecated, may not be - supported in future Zebra versions, and should definitely + supported in future &zebra; versions, and should definitely not be used in production code.
- IDXPATH Use Attributes (type = 1) + &acro.idxpath; Use Attributes (type = 1) - This attribute set allows one to search GRS filter indexed - records by XPATH like structured index names. + This attribute set allows one to search &acro.grs1; filter indexed + records by &acro.xpath; like structured index names. @@ -1827,13 +1848,13 @@ index names, which might clash with your own index names. - + - Zebra specific IDXPATH Use Attributes (type 1) + &zebra; specific &acro.idxpath; Use Attributes (type 1) - IDXPATH + &acro.idxpath; Value String Index Notes @@ -1841,31 +1862,31 @@ - XPATH Begin + &acro.xpath; Begin 1 _XPATH_BEGIN deprecated - XPATH End + &acro.xpath; End 2 _XPATH_END deprecated - XPATH CData + &acro.xpath; CData 1016 _XPATH_CDATA deprecated - XPATH Attribute Name + &acro.xpath; Attribute Name 3 _XPATH_ATTR_NAME deprecated - XPATH Attribute CData + &acro.xpath; Attribute CData 1015 _XPATH_ATTR_CDATA deprecated @@ -1878,22 +1899,22 @@ See tab/idxpath.att for more information. - Search for all documents starting with root element + Search for all documents starting with root element /root (either using the numeric or the string use attributes): - Z> find @attrset idxpath @attr 1=1 @attr 4=3 root/ - Z> find @attr idxpath 1=1 @attr 4=3 root/ - Z> find @attr 1=_XPATH_BEGIN @attr 4=3 root/ + Z> find @attrset idxpath @attr 1=1 @attr 4=3 root/ + Z> find @attr idxpath 1=1 @attr 4=3 root/ + Z> find @attr 1=_XPATH_BEGIN @attr 4=3 root/ - Search for all documents where specific nested XPATH + Search for all documents where specific nested &acro.xpath; /c1/c2/../cn exists. Notice the very counter-intuitive reverse notation! - Z> find @attrset idxpath @attr 1=1 @attr 4=3 cn/cn-1/../c1/ - Z> find @attr 1=_XPATH_BEGIN @attr 4=3 cn/cn-1/../c1/ + Z> find @attrset idxpath @attr 1=1 @attr 4=3 cn/cn-1/../c1/ + Z> find @attr 1=_XPATH_BEGIN @attr 4=3 cn/cn-1/../c1/ @@ -1904,19 +1925,19 @@ - Search for CDATA string anothertext in any - attribute: - + Search for CDATA string anothertext in any + attribute: + Z> find @attrset idxpath @attr 1=1015 anothertext Z> find @attr 1=_XPATH_ATTR_CDATA anothertext - Search for all documents with have an XML element node - including an XML attribute named creator - - Z> find @attrset idxpath @attr 1=3 @attr 4=3 creator - Z> find @attr 1=_XPATH_ATTR_NAME @attr 4=3 creator + Search for all documents with have an &acro.xml; element node + including an &acro.xml; attribute named creator + + Z> find @attrset idxpath @attr 1=3 @attr 4=3 creator + Z> find @attr 1=_XPATH_ATTR_NAME @attr 4=3 creator @@ -1930,7 +1951,7 @@ Scanning is supported on all idxpath indexes, both specified as numeric use attributes, or as string - index names. + index names. Z> scan @attrset idxpath @attr 1=1016 text Z> scan @attr 1=_XPATH_ATTR_CDATA anothertext @@ -1943,27 +1964,27 @@
- Mapping from PQF atomic APT queries to Zebra internal + <title>Mapping from &acro.pqf; atomic &acro.apt; queries to &zebra; internal register indexes - The rules for PQF APT mapping are rather tricky to grasp in the + The rules for &acro.pqf; &acro.apt; mapping are rather tricky to grasp in the first place. We deal first with the rules for deciding which internal register or string index to use, according to the use attribute or access point specified in the query. Thereafter we deal with the rules for determining the correct structure type of - the named register. + the named register. -
- Mapping of PQF APT access points - - Zebra understands four fundamental different types of access - points, of which only the +
+ Mapping of &acro.pqf; &acro.apt; access points + + &zebra; understands four fundamental different types of access + points, of which only the numeric use attribute type access points - are defined by the Z39.50 + are defined by the &acro.z3950; standard. - All other access point types are Zebra specific, and non-portable. - + All other access point types are &zebra; specific, and non-portable. +
Access point name mapping @@ -1975,86 +1996,86 @@ GrammarNotes - - - - Use attribute - numeric - [1-9][1-9]* - directly mapped to string index name - - - String index name - string - [a-zA-Z](\-?[a-zA-Z0-9])* - normalized name is used as internal string index name - - - Zebra internal index name - zebra - _[a-zA-Z](_?[a-zA-Z0-9])* - hardwired internal string index name - - - XPATH special index - XPath - /.* - special xpath search for GRS indexed records - + + + + Use attribute + numeric + [1-9][1-9]* + directly mapped to string index name + + + String index name + string + [a-zA-Z](\-?[a-zA-Z0-9])* + normalized name is used as internal string index name + + + &zebra; internal index name + zebra + _[a-zA-Z](_?[a-zA-Z0-9])* + hardwired internal string index name + + + &acro.xpath; special index + XPath + /.* + special xpath search for &acro.grs1; indexed records +
- + - Attribute set names and + Attribute set names and string index names are normalizes according to the following rules: all single hyphens '-' are stripped, and all upper case letters are folded to lower case. - + - Numeric use attributes are mapped - to the Zebra internal + Numeric use attributes are mapped + to the &zebra; internal string index according to the attribute set definition in use. - The default attribute set is Bib-1, and may be - omitted in the PQF query. + The default attribute set is &acro.bib1;, and may be + omitted in the &acro.pqf; query. - + According to normalization and numeric use attribute mapping, it follows that the following - PQF queries are considered equivalent (assuming the default + &acro.pqf; queries are considered equivalent (assuming the default configuration has not been altered): - Z> find @attr 1=Body-of-text serenade - Z> find @attr 1=bodyoftext serenade - Z> find @attr 1=BodyOfText serenade - Z> find @attr 1=bO-d-Y-of-tE-x-t serenade - Z> find @attr 1=1010 serenade - Z> find @attrset Bib-1 @attr 1=1010 serenade - Z> find @attrset bib1 @attr 1=1010 serenade - Z> find @attrset Bib1 @attr 1=1010 serenade - Z> find @attrset b-I-b-1 @attr 1=1010 serenade - - + Z> find @attr 1=Body-of-text serenade + Z> find @attr 1=bodyoftext serenade + Z> find @attr 1=BodyOfText serenade + Z> find @attr 1=bO-d-Y-of-tE-x-t serenade + Z> find @attr 1=1010 serenade + Z> find @attrset bib1 @attr 1=1010 serenade + Z> find @attrset bib1 @attr 1=1010 serenade + Z> find @attrset Bib1 @attr 1=1010 serenade + Z> find @attrset b-I-b-1 @attr 1=1010 serenade + + - + The numerical - use attributes (type 1) + use attributes (type 1) are interpreted according to the attribute sets which have been loaded in the zebra.cfg file, and are matched against specific fields as specified in the .abs file which describes the profile of the records which have been loaded. - If no use attribute is provided, a default of - Bib-1 Use Any (1016) is assumed. + If no use attribute is provided, a default of + &acro.bib1; Use Any (1016) is assumed. The predefined use attribute sets can be reconfigured by tweaking the configuration files - tab/*.att, and + tab/*.att, and new attribute sets can be defined by adding similar files in the - configuration path profilePath of the server. - + configuration path profilePath of the server. + String indexes can be accessed directly, @@ -2062,27 +2083,27 @@ ignored. The above mentioned name normalization applies. String index names are defined in the used indexing filter configuration files, for example in the - GRS + &acro.grs1; *.abs configuration files, or in the - alvis filter XSLT indexing stylesheets. + alvis filter &acro.xslt; indexing stylesheets. - Zebra internal indexes can be accessed directly, + &zebra; internal indexes can be accessed directly, according to the same rules as the user defined - string indexes. The only difference is that - Zebra internal index names are hardwired, + string indexes. The only difference is that + &zebra; internal index names are hardwired, all uppercase and - must start with the character '_'. + must start with the character '_'. - Finally, XPATH access points are only - available using the GRS filter for indexing. + Finally, &acro.xpath; access points are only + available using the &acro.grs1; filter for indexing. These access point names must start with the character '/', they are not - normalized, but passed unaltered to the Zebra internal - XPATH engine. See . + normalized, but passed unaltered to the &zebra; internal + &acro.xpath; engine. See . @@ -2090,15 +2111,15 @@
-
- Mapping of PQF APT structure and completeness to + <section id="querymodel-pqf-apt-mapping-structuretype"> + <title>Mapping of &acro.pqf; &acro.apt; structure and completeness to register type - - Internally Zebra has in it's default configuration several - different types of registers or indexes, whose tokenization and - character normalization rules differ. This reflects the fact that + + Internally &zebra; has in its default configuration several + different types of registers or indexes, whose tokenization and + character normalization rules differ. This reflects the fact that searching fundamental different tokens like dates, numbers, - bitfields and string based text needs different rule sets. + bitfields and string based text needs different rule sets. @@ -2115,7 +2136,7 @@ - phrase (@attr 4=1), word (@attr 4=2), + phrase (@attr 4=1), word (@attr 4=2), word-list (@attr 4=6), free-form-text (@attr 4=105), or document-text (@attr 4=106) @@ -2125,7 +2146,7 @@ - phrase (@attr 4=1), word (@attr 4=2), + phrase (@attr 4=1), word (@attr 4=2), word-list (@attr 4=6), free-form-text (@attr 4=105), or document-text (@attr 4=106) @@ -2144,26 +2165,26 @@ numeric (@attr 4=109) ignored - Numeric ('u') + Numeric ('n') Special index for digital numbers key (@attr 4=3) ignored Null bitmap ('0') - Used for non-tokenizated and non-normalized bit sequences + Used for non-tokenized and non-normalized bit sequences year (@attr 4=4) ignored Year ('y') - Non-tokenizated and non-normalized 4 digit numbers + Non-tokenized and non-normalized 4 digit numbers date (@attr 4=5) ignored Date ('d') - Non-tokenizated and non-normalized ISO date strings + Non-tokenized and non-normalized ISO date strings ignored @@ -2175,59 +2196,59 @@ overruled overruled special - Internal record ID register, used whenever + Internal record ID register, used whenever Relation Always Matches (@attr 2=103) is specified
- + - - - If a Structure attribute of - Phrase is used in conjunction with a - Completeness attribute of - Complete (Sub)field, the term is matched - against the contents of the phrase (long word) register, if one - exists for the given Use attribute. - A phrase register is created for those fields in the - GRS *.abs file that contains a - p-specifier. + + + If a Structure attribute of + Phrase is used in conjunction with a + Completeness attribute of + Complete (Sub)field, the term is matched + against the contents of the phrase (long word) register, if one + exists for the given Use attribute. + A phrase register is created for those fields in the + &acro.grs1; *.abs file that contains a + p-specifier. - Z> scan @attr 1=Title @attr 4=1 @attr 6=3 beethoven + Z> scan @attr 1=Title @attr 4=1 @attr 6=3 beethoven ... bayreuther festspiele (1) * beethoven bibliography database (1) benny carter (1) ... - Z> find @attr 1=Title @attr 4=1 @attr 6=3 "beethoven bibliography" + Z> find @attr 1=Title @attr 4=1 @attr 6=3 "beethoven bibliography" ... Number of hits: 0, setno 5 ... - Z> find @attr 1=Title @attr 4=1 @attr 6=3 "beethoven bibliography database" + Z> find @attr 1=Title @attr 4=1 @attr 6=3 "beethoven bibliography database" ... Number of hits: 1, setno 6 - - + + - - If Structure=Phrase is - used in conjunction with Incomplete Field - the - default value for Completeness, the - search is directed against the normal word registers, but if the term - contains multiple words, the term will only match if all of the words - are found immediately adjacent, and in the given order. - The word search is performed on those fields that are indexed as - type w in the GRS *.abs file. + + If Structure=Phrase is + used in conjunction with Incomplete Field - the + default value for Completeness, the + search is directed against the normal word registers, but if the term + contains multiple words, the term will only match if all of the words + are found immediately adjacent, and in the given order. + The word search is performed on those fields that are indexed as + type w in the &acro.grs1; *.abs file. - Z> scan @attr 1=Title @attr 4=1 @attr 6=1 beethoven + Z> scan @attr 1=Title @attr 4=1 @attr 6=1 beethoven ... - beefheart (1) + beefheart (1) * beethoven (18) - beethovens (7) + beethovens (7) ... - Z> find @attr 1=Title @attr 4=1 @attr 6=1 beethoven + Z> find @attr 1=Title @attr 4=1 @attr 6=1 beethoven ... Number of hits: 18, setno 1 ... @@ -2235,74 +2256,74 @@ ... Number of hits: 2, setno 2 ... - - + + - - If the Structure attribute is - Word List, - Free-form Text, or - Document Text, the term is treated as a - natural-language, relevance-ranked query. - This search type uses the word register, i.e. those fields - that are indexed as type w in the - GRS *.abs file. - + + If the Structure attribute is + Word List, + Free-form Text, or + Document Text, the term is treated as a + natural-language, relevance-ranked query. + This search type uses the word register, i.e. those fields + that are indexed as type w in the + &acro.grs1; *.abs file. + - - If the Structure attribute is - Numeric String the term is treated as an integer. - The search is performed on those fields that are indexed - as type n in the GRS + + If the Structure attribute is + Numeric String the term is treated as an integer. + The search is performed on those fields that are indexed + as type n in the &acro.grs1; *.abs file. - + - - If the Structure attribute is - URX the term is treated as a URX (URL) entity. - The search is performed on those fields that are indexed as type - u in the *.abs file. - + + If the Structure attribute is + URX the term is treated as a URX (URL) entity. + The search is performed on those fields that are indexed as type + u in the *.abs file. + - - If the Structure attribute is - Local Number the term is treated as - native Zebra Record Identifier. - + + If the Structure attribute is + Local Number the term is treated as + native &zebra; Record Identifier. + - - If the Relation attribute is - Equals (default), the term is matched - in a normal fashion (modulo truncation and processing of - individual words, if required). - If Relation is Less Than, - Less Than or Equal, - Greater than, or Greater than or - Equal, the term is assumed to be numerical, and a - standard regular expression is constructed to match the given - expression. - If Relation is Relevance, - the standard natural-language query processor is invoked. - + + If the Relation attribute is + Equals (default), the term is matched + in a normal fashion (modulo truncation and processing of + individual words, if required). + If Relation is Less Than, + Less Than or Equal, + Greater than, or Greater than or + Equal, the term is assumed to be numerical, and a + standard regular expression is constructed to match the given + expression. + If Relation is Relevance, + the standard natural-language query processor is invoked. + - - For the Truncation attribute, - No Truncation is the default. - Left Truncation is not supported. - Process # in search term is supported, as is - Regxp-1. - Regxp-2 enables the fault-tolerant (fuzzy) - search. As a default, a single error (deletion, insertion, - replacement) is accepted when terms are matched against the register - contents. - + + For the Truncation attribute, + No Truncation is the default. + Left Truncation is not supported. + Process # in search term is supported, as is + Regxp-1. + Regxp-2 enables the fault-tolerant (fuzzy) + search. As a default, a single error (deletion, insertion, + replacement) is accepted when terms are matched against the register + contents. + -
+
- Zebra Regular Expressions in Truncation Attribute (type = 5) - + &zebra; Regular Expressions in Truncation Attribute (type = 5) + Each term in a query is interpreted as a regular expression if the truncation value is either Regxp-1 (@attr 5=102) @@ -2329,29 +2350,29 @@ - + The above operands can be combined with the following operators: - + Regular Expression Operators x* - Matches x zero or more times. + Matches x zero or more times. Priority: high. x+ - Matches x one or more times. + Matches x one or more times. Priority: high. x? - Matches x zero or once. + Matches x zero or once. Priority: high. @@ -2369,16 +2390,16 @@ The order of evaluation may be changed by using parentheses. - -
- + + + If the first character of the Regxp-2 query is a plus character (+) it marks the beginning of a section with non-standard specifiers. The next plus character marks the end of the section. - Currently Zebra only supports one specifier, the error tolerance, - which consists one digit. + Currently &zebra; only supports one specifier, the error tolerance, + which consists one digit. @@ -2406,89 +2427,88 @@
- +
- Server Side CQL to PQF Query Translation + Server Side &acro.cql; to &acro.pqf; Query Translation Using the <cql2rpn>l2rpn.txt</cql2rpn> - YAZ Frontend Virtual + &yaz; Frontend Virtual Hosts option, one can configure - the YAZ Frontend CQL-to-PQF - converter, specifying the interpretation of various - CQL + the &yaz; Frontend &acro.cql;-to-&acro.pqf; + converter, specifying the interpretation of various + &acro.cql; indexes, relations, etc. in terms of Type-1 query attributes. - + - For example, using server-side CQL-to-PQF conversion, one might + For example, using server-side &acro.cql;-to-&acro.pqf; conversion, one might query a zebra server like this: - querytype cql Z> find text=(plant and soil) ]]> - and - if properly configured - even static relevance ranking can - be performed using CQL query syntax: + and - if properly configured - even static relevance ranking can + be performed using &acro.cql; query syntax: - find text = /relevant (plant and soil) ]]> - + - By the way, the same configuration can be used to - search using client-side CQL-to-PQF conversion: - (the only difference is querytype cql2rpn - instead of + By the way, the same configuration can be used to + search using client-side &acro.cql;-to-&acro.pqf; conversion: + (the only difference is querytype cql2rpn + instead of querytype cql, and the call specifying a local conversion file) - querytype cql2rpn Z> find text=(plant and soil) ]]> - + Exhaustive information can be found in the - Section "Specification of CQL to RPN mappings" in the YAZ manual. - , - and shall therefore not be repeated here. - - -
+
-
+