Zend_Search_Lucene-QueryLanguage.xml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21829 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.search.lucene.query-language">
  5. <title>Abfragesprache</title>
  6. <para>
  7. Java Lucene und <classname>Zend_Search_Lucene</classname> bieten sehr mächtige
  8. Abfragesprachen.
  9. </para>
  10. <para>
  11. Diese Sprachen sind großteils die selben mit ein paar kleineren Unterschieden welche
  12. anbei erklärt werden.
  13. </para>
  14. <para>
  15. Die komplette Java Lucene Syntax Dokumentation der Abfragesprache kann
  16. <ulink url="http://lucene.apache.org/java/2_3_0/queryparsersyntax.html">hier</ulink>
  17. gefunden werden.
  18. </para>
  19. <sect2 id="zend.search.lucene.query-language.terms">
  20. <title>Ausdrücke</title>
  21. <para>
  22. Eine Abfrage wird in Ausdrücke und Operatoren zerteilt. Es gibt drei Arten von
  23. Ausdrücken: Einzelne Ausdrücke, Phrasen und Unterabfragen.
  24. </para>
  25. <para>
  26. Ein einzelner Ausdruck ist ein einzelnes Wort wie "Test" oder "Hallo".
  27. </para>
  28. <para>
  29. Eine Phrase ist eine Gruppe von Wörtern die von doppelten Hochkommata umgeben sind wie
  30. "Hallo Dolly".
  31. </para>
  32. <para>
  33. Eine Unterabfrage ist eine Abfrage die von Klammern umgeben ist wie "(Hallo Dolly)".
  34. </para>
  35. <para>
  36. Mehrere Ausdrücke können mithilfe eines boolschen Operators miteinander kombiniert
  37. werden um komplexere Abfragen zu formen (siehe anbei).
  38. </para>
  39. </sect2>
  40. <sect2 id="zend.search.lucene.query-language.fields">
  41. <title>Felder</title>
  42. <para>
  43. Lucene unterstützt Felder von Daten. Wenn eine Suche durchgeführt wird kann man entweder
  44. ein Feld spezifizieren, oder ein Standardfeld verwenden. Der Name des Feldes hängt von
  45. den indizierten Daten ab und das Standardfeld wird durch aktuelle Einstellungen
  46. definiert.
  47. </para>
  48. <para>
  49. Der erste und größte Unterschied zu Java Lucene ist der das Ausdrücke standardmäßig
  50. über <emphasis>alle Felder</emphasis> gesucht werden.
  51. </para>
  52. <para>
  53. Es gibt zwei statische Methoden in der <classname>Zend_Search_Lucene</classname> Klasse
  54. welche dem Entwickler das Konfigurieren dieser Einstellungen erlauben:
  55. </para>
  56. <programlisting language="php"><![CDATA[
  57. $defaultSearchField = Zend_Search_Lucene::getDefaultSearchField();
  58. ...
  59. Zend_Search_Lucene::setDefaultSearchField('contents');
  60. ]]></programlisting>
  61. <para>
  62. Der <constant>NULL</constant> Wert bedeutet, das die Suche über alle Felder durchgeführt
  63. wird. Das ist die Standardeinstellung.
  64. </para>
  65. <para>
  66. Es können spezielle Felder gesucht werden indem der Feldname gefolgt von einem
  67. Doppelpunkt ":" angegeben wird, gefolgt von dem Begriff nach dem gesucht wird.
  68. </para>
  69. <para>
  70. Als Beispiel nehmen wir an das ein Lucene Index zwei Felder enthält - title und text -
  71. text ist das Standardfeld. Wenn man das "Der richtige Weg" benannte Dokument finden will
  72. welches den Text "gehe nicht diesen Weg" enthält, geht das mit:
  73. </para>
  74. <programlisting language="querystring"><![CDATA[
  75. title:"Der richtige Weg" AND text:go
  76. ]]></programlisting>
  77. <para>
  78. oder
  79. </para>
  80. <programlisting language="querystring"><![CDATA[
  81. title:"Mach es richtig" AND go
  82. ]]></programlisting>
  83. <para>
  84. Weil "text" das Standardfeld ist, wird der Feld Indikator nicht benötigt.
  85. </para>
  86. <para>
  87. Beachte: Das Feld nur nur für den Ausdruck, die Phrase oder die Unterabfrage gültig die
  88. direkt danach folgt, sodas die Abfrage
  89. </para>
  90. <programlisting language="querystring"><![CDATA[
  91. title:Mach es richtig
  92. ]]></programlisting>
  93. <para>
  94. nur "Mach" im title Feld finden wird. Es findet "es" und "richtig" im Standardfeld (wenn
  95. das Standardfeld gesetzt ist) oder in allen indizierten Felder (wenn das Standardfeld
  96. auf <constant>NULL</constant> gesetzt ist).
  97. </para>
  98. </sect2>
  99. <sect2 id="zend.search.lucene.query-language.wildcard">
  100. <title>Wildcards</title>
  101. <para>
  102. Lucene unterstützt Einzelzeichen und Mehrfachzeichen Suchen mit Wildcards in einzelnen
  103. Ausdrücken (aber nicht innerhalb von Phrasenabfragen).
  104. </para>
  105. <para>
  106. Um eine Einzelzeichen Wildcardsuche durchzuführen kann das "?" Zeichen verwendet werden.
  107. </para>
  108. <para>
  109. Um eine Mehrzeichen Wildcardsuche durchzuführen kann das "*" Zeichen verwendet werden.
  110. </para>
  111. <para>
  112. Die Einzelzeichen Wildcardsuche schucht nach Strings die dem Begriff entsprechen wobei
  113. das "?" durch ein beliebiges einzelnes Zeichen ersetzt wird. Um, zum Beispiel, nach
  114. "Text" oder "Test" zu suchen kann die folgende Suche verwendet werden:
  115. </para>
  116. <programlisting language="querystring"><![CDATA[
  117. Te?t
  118. ]]></programlisting>
  119. <para>
  120. Mehrzeichen Wildcardsuche sucht nach 0 oder mehr Zeichen wenn Strings nach passenden
  121. Begriffen sucht. Um, zum Beispiel, nach Test, Tests oder Tester zu suchen, kann die
  122. folgende Suche verwendet werden:
  123. </para>
  124. <programlisting language="querystring"><![CDATA[
  125. Test*
  126. ]]></programlisting>
  127. <para>
  128. Es können "?", "*" oder beide an jeder Stelle des Ausdrucks verwendet werden:
  129. </para>
  130. <programlisting language="querystring"><![CDATA[
  131. *schrei?t*
  132. ]]></programlisting>
  133. <para>
  134. Sucht nach "schreibt", "schreibtisch", "beschreibt", "schreist" und so weiter.
  135. </para>
  136. <para>
  137. Beginnend mit ZF 1.7.7 benötigen Wildcard Präfixe einen nicht-Wildcard Präfix. Die
  138. standardmäßige Länge des Präfixes ist 3 (wie in Java Lucene). Die Ausdrücke
  139. "*", "te?t", "*wr?t*" werden also eine Exception werfen
  140. <footnote>
  141. <para>
  142. Es ist zu beachten das es nicht zu einer
  143. <code>Zend_Search_Lucene_Search_QueryParserException</code> kommt, sondern zu
  144. einer <code>Zend_Search_Lucene_Exception</code>. Sie wird wärend dem
  145. Umschreiben der Abfrage geworfen.
  146. </para>
  147. </footnote>.
  148. </para>
  149. <para>
  150. Das kann durch Verwendung der Methoden
  151. <code>Zend_Search_Lucene_Search_Query_Wildcard::getMinPrefixLength()</code> und
  152. <code>Zend_Search_Lucene_Search_Query_Wildcard::setMinPrefixLength()</code> geändert
  153. werden.
  154. </para>
  155. </sect2>
  156. <sect2 id="zend.search.lucene.query-language.modifiers">
  157. <title>Ausdrücke verändern</title>
  158. <para>
  159. Lucene unterstützt die Veränderung von Abfrageausdrücken und bietet damit ein beites
  160. Spektrum von Suchoptionen.
  161. </para>
  162. <para>
  163. Der "~" Modifikator kann für verwendet werden um eine annähernde Suche auf Phrasen oder
  164. Fuzzy Suchen für individuelle Ausdrücke durchzuführen.
  165. </para>
  166. </sect2>
  167. <sect2 id="zend.search.lucene.query-language.range">
  168. <title>Bereichs Suchen</title>
  169. <para>
  170. Bereichsabfragen erlauben es Entwicklern passende Dokumente zu finden deren Werte der
  171. Felder zwischen der unteren und oberen Grenze sind die durch die Bereichsabfrage
  172. spezifiziert wurden. Bereichsabfragen können inklusive oder exklusive der oberen und
  173. unteren Grenze sein. Sortierungen werden lexikalisch durchgeführt.
  174. </para>
  175. <programlisting language="querystring"><![CDATA[
  176. mod_date:[20020101 TO 20030101]
  177. ]]></programlisting>
  178. <para>
  179. Das wird Dokumente finden dessen lod_date Felder Werte zwischen 20020101 und 20030101
  180. inklusive haben. Es ist zu beachten das Bereichsabfragen nicht für Datumsfelder
  181. reserviert sind. Bereichsabfragen können auch mit nicht-datums Felder verwendet werden:
  182. </para>
  183. <programlisting language="querystring"><![CDATA[
  184. title:{Aida TO Carmen}
  185. ]]></programlisting>
  186. <para>
  187. Das wird alle Dokumente finden dessen Titel zwischen Aida und Carmen sortiert sind,
  188. aber ohne Aida und Carmen.
  189. </para>
  190. <para>
  191. Bereichsabfragen inklusive, werden durch eine eckige Klammer abgegrenzt.
  192. Bereichsabfragen exklusive werden durch geschlungene Klammern abgegrenzt.
  193. </para>
  194. <para>
  195. Wenn kein Feld spezifiziert wurde sucht <classname>Zend_Search_Lucene</classname>
  196. standardmäßig nach spezifizierten Intervallen in allen Feldern.
  197. </para>
  198. <programlisting language="querystring"><![CDATA[
  199. {Aida TO Carmen}
  200. ]]></programlisting>
  201. </sect2>
  202. <sect2 id="zend.search.lucene.query-language.fuzzy">
  203. <title>Fuzzy Suchen</title>
  204. <para>
  205. <classname>Zend_Search_Lucene</classname> unterstützt, genauso wie Java Lucene, die
  206. Fuzzy Suche basierend auf der Levenshtein Distanz oder dem Edit Algorithmus. Um eine
  207. Fuzzy Suche durchzuführen muß das Tilde Symbol "~", am Ende eines einzelnen Wortbegriffs
  208. verwendet werden. Um zum Beispiel nach einem Begriff zu suchen der in der Aussprache
  209. ähnlich zu "Raum" ist kann die folgende Fuzzy Suche verwendet werden:
  210. </para>
  211. <programlisting language="querystring"><![CDATA[
  212. roam~
  213. ]]></programlisting>
  214. <para>
  215. Diese Suche wird Begriffe wie "Baum" und "Saum" finden. Zusätzliche (optionale)
  216. Parameter können die benötigte Ähnlichkeit spezifizieren. Der Wert muß zwischen 0 und 1
  217. sein. Mit einem Wert näher bei 1 werden nur Begriffe mit einer höheren Warscheinlichkeit
  218. gefunden. Zum Beispiel:
  219. </para>
  220. <programlisting language="querystring"><![CDATA[
  221. roam~0.8
  222. ]]></programlisting>
  223. <para>
  224. Der verwendete Standardwert wenn der Parameter nicht angegeben wurde ist 0.5.
  225. </para>
  226. </sect2>
  227. <sect2 id="zend.search.lucene.query-language.matched-terms-limitations">
  228. <title>Einschränkung passender Ausdrücke</title>
  229. <para>
  230. Wildcard, Bereichs- und Fuzzy Suchabfragen können bei zu vielen Ausdrücken passen.
  231. Das kann die Geschwindigkeit der Suche sehr stark verlangsamen.
  232. </para>
  233. <para>
  234. Deshalb setzt <classname>Zend_Search_Lucene</classname> ein Limit der passenden
  235. Ausdrücke pro Abfrage (Unterabfrage). Dieses Limit kann durch Verwendung der Methoden
  236. <code>Zend_Search_Lucene::getTermsPerQueryLimit()</code>/
  237. <code>Zend_Search_Lucene::setTermsPerQueryLimit($limit)</code> empfangen und gesetzt
  238. werden.
  239. </para>
  240. <para>
  241. Das standardmäßige Limit für passende Ausdrücke ist 1024.
  242. </para>
  243. </sect2>
  244. <sect2 id="zend.search.lucene.query-language.proximity-search">
  245. <title>Angenäherte Suchen</title>
  246. <para>
  247. Lucene unterstützt das Finden von Wörtern aus einer Phrase die einen spezifizierten
  248. Abstand an Wörtern in einem String weg sind. Um eine angenäherte Suche durchzuführen muß
  249. das Tilde, "~", Symbol am Ende der Phrase verwendet werden. Um zum Beispiel nach "Zend"
  250. und "Framework" innerhalb von 10 Wörtern zueinander in einem Dokument zu suchen kann die
  251. folgende Suche verwendet werden:
  252. </para>
  253. <programlisting language="querystring"><![CDATA[
  254. "Zend Framework"~10
  255. ]]></programlisting>
  256. </sect2>
  257. <sect2 id="zend.search.lucene.query-language.boosting">
  258. <title>Einen Ausdruck schneller machen</title>
  259. <para>
  260. Java Lucene und <classname>Zend_Search_Lucene</classname> bieten einen Level der
  261. Relevanz von passenden Dokumenten basierend auf den gefundenen Ausdrücken. Um die
  262. Relevanz eines Ausdrucks zu erhöhen kann das Karet, "^", Symbol mit einem Boost Faktor
  263. (einer Zahl) am Ende des Ausdrucks nach dem gesucht wird, verwendet werden. Je höher
  264. Boost Faktor ist, desdo relevanter wird der Ausdruck werden.
  265. </para>
  266. <para>
  267. Das boosten erlaubt die Kontrolle der Relevanz eines Dokuments durch das boosten
  268. individueller Ausdrücke. Wenn man zum Beispiel nach
  269. </para>
  270. <programlisting language="querystring"><![CDATA[
  271. PHP framework
  272. ]]></programlisting>
  273. <para>
  274. sucht und will das der Ausdruck "PHP" mehr Relevanz hat, kann er durch Verwendung des ^
  275. Symbols zusammen mit einem Boost Faktor beim Ausdruck geboostet werden. Man würde zum
  276. Beispiel folgendes angeben:
  277. </para>
  278. <programlisting language="querystring"><![CDATA[
  279. PHP^4 framework
  280. ]]></programlisting>
  281. <para>
  282. Das macht Dokumente in denen der Ausdruck <acronym>PHP</acronym> vorkommt relevanter.
  283. Man kann genauso Phrasenausdrücke boosten und Unterabfragen wie im Beispiel gezeigt:
  284. </para>
  285. <programlisting language="querystring"><![CDATA[
  286. "PHP framework"^4 "Zend Framework"
  287. ]]></programlisting>
  288. <para>
  289. Standardwert ist der Boost Faktor 1. Auch wenn der Boost Faktor positiv sein muß, kann
  290. er kleiner als 1 sein (z.B. 0.2).
  291. </para>
  292. </sect2>
  293. <sect2 id="zend.search.lucene.query-language.boolean">
  294. <title>Boolsche Operatoren</title>
  295. <para>
  296. Boolsche Operatoren erlauben es Ausdrücke durch logische Operatoren zu kombinieren.
  297. Lucene unterstützt AND, "+", OR, NOT und "-" als boolsche Operatoren. In Java Lucene
  298. müssen alle boolschen Operatoren GROßGESCHRIEBEN werden. In
  299. <classname>Zend_Search_Lucene</classname> nicht.
  300. </para>
  301. <para>
  302. AND, OR, und NOT Operatoren und "+", "-" definieren zwei unterschiedliche Stile um
  303. boolsche Abfragen zu erstellen. Im Gegensatz zu Java Lucene erlaubt es
  304. <classname>Zend_Search_Lucene</classname> nicht diese zwei Stile zu mischen.
  305. </para>
  306. <para>
  307. Wenn der AND/OR/NOT Stil verwendet wird dann muß der AND oder OR Operator zwischen allen
  308. Abfrageausdrücken vorhanden sein. Jedem Ausdruck kann auch ein NOT Operator
  309. vorangestellt werden. Der AND Operator hat eine höhere Präzedenz als der OR Operator.
  310. Das unterscheidet sich vom Verhalten von Java Lucene.
  311. </para>
  312. <sect3 id="zend.search.lucene.query-language.boolean.and">
  313. <title>AND</title>
  314. <para>
  315. Der AND Operator bedeutet das alle Ausdrücke der "AND Gruppe" in einigen Teilen der
  316. gesuchten Feld(er) passen müssen.
  317. </para>
  318. <para>
  319. Um nach Dokumenten zu Suchen die "PHP Framework" und "Zend Framework" enthalten kann
  320. die folgende Abfrage verwendet werden:
  321. </para>
  322. <programlisting language="querystring"><![CDATA[
  323. "PHP Framework" AND "Zend Framework"
  324. ]]></programlisting>
  325. </sect3>
  326. <sect3 id="zend.search.lucene.query-language.boolean.or">
  327. <title>OR</title>
  328. <para>
  329. Der OR Operator teilt die Abfrage in verschiedene optionale Begriffe.
  330. </para>
  331. <para>
  332. Um nach Dokumenten zu Suchen die "PHP Framework" oder "Zend Framework" enthalten
  333. kann die folgende Abfrage verwendet werden:
  334. </para>
  335. <programlisting language="querystring"><![CDATA[
  336. "PHP Framework" OR "Zend Framework"
  337. ]]></programlisting>
  338. </sect3>
  339. <sect3 id="zend.search.lucene.query-language.boolean.not">
  340. <title>NOT</title>
  341. <para>
  342. Der NOT Operator scheidet Dokumente aus die den Ausdruck nach NOT enthalten. Aber
  343. eine "AND Gruppe" die nur Ausdrücke mit NOT Operatoren enthält, gibt ein leeres
  344. Ergebnis zurück statt einem kompletten Set von indizierten Dokumenten.
  345. </para>
  346. <para>
  347. Um nach Dokumenten zu Suchen die "PHP Framework" enthalten aber "Zend Framework"
  348. nicht kann die folgende Abfrage verwendet werden:
  349. </para>
  350. <programlisting language="querystring"><![CDATA[
  351. "PHP Framework" AND NOT "Zend Framework"
  352. ]]></programlisting>
  353. </sect3>
  354. <sect3 id="zend.search.lucene.query-language.boolean.other-form">
  355. <title>&amp;&amp;, ||, und ! Operatoren</title>
  356. <para>
  357. &amp;&amp;, ||, und ! können statt den AND, OR und NOT Notation verwendet werden.
  358. </para>
  359. </sect3>
  360. <sect3 id="zend.search.lucene.query-language.boolean.plus">
  361. <title>+</title>
  362. <para>
  363. Der "+" oder benötigende Operator erfordert das der Ausdruck nach dem "+" Symbol im
  364. passenden Dokument vorhanden ist.
  365. </para>
  366. <para>
  367. Um nach Dokumenten zu Suchen die "Zend" enthalten müssen und "Framework" enthalten
  368. können, kann die folgende Abfrage verwendet werden:
  369. </para>
  370. <programlisting language="querystring"><![CDATA[
  371. +Zend Framework
  372. ]]></programlisting>
  373. </sect3>
  374. <sect3 id="zend.search.lucene.query-language.boolean.minus">
  375. <title>-</title>
  376. <para>
  377. Der "-" oder ausschließende Operator schließt Dokumente aus die dem Ausdruck nach
  378. dem "-" Symbol entsprechen.
  379. </para>
  380. <para>
  381. Um nach Dokumenten zu Suchen die "PHP Framework" enthalten aber "Zend Framework"
  382. nicht, kann die folgende Abfrage verwendet werden:
  383. </para>
  384. <programlisting language="querystring"><![CDATA[
  385. "PHP Framework" -"Zend Framework"
  386. ]]></programlisting>
  387. </sect3>
  388. <sect3 id="zend.search.lucene.query-language.boolean.no-operator">
  389. <title>kein Operator</title>
  390. <para>
  391. Wenn kein Operator verwendet wird, dann wird das Suchverhalten durch den
  392. "standardmäßigen boolschen Operator" bestimmt.
  393. </para>
  394. <para>
  395. Dieser ist standardmäßig auf <code>OR</code> gesetzt.
  396. </para>
  397. <para>
  398. Das impliziert das jeder Ausdruck standardmäßig optional ist. Er kann oder kann
  399. nicht innerhalb des Dokuments enthalten sein, aber Dokumenten mit diesem Ausdruck
  400. haben einen Höheren Stellenwert.
  401. </para>
  402. <para>
  403. Um nach Dokumenten zu Suchen die "PHP Framework" benötigen und "Zend Framework"
  404. enthalten können kann die folgende Abfrage verwendet werden:
  405. </para>
  406. <programlisting language="querystring"><![CDATA[
  407. +"PHP Framework" "Zend Framework"
  408. ]]></programlisting>
  409. <para>
  410. Der standardmäßige boolsche Operator kann mit den
  411. <classname>Zend_Search_Lucene_Search_QueryParser::setDefaultOperator($operator)</classname>
  412. und
  413. <classname>Zend_Search_Lucene_Search_QueryParser::getDefaultOperator()</classname>
  414. Methoden gesetzt oder geholt werden.
  415. </para>
  416. <para>
  417. Diese Methoden arbeiten mit den
  418. <classname>Zend_Search_Lucene_Search_QueryParser::B_AND</classname> und
  419. <classname>Zend_Search_Lucene_Search_QueryParser::B_OR</classname> Konstanten.
  420. </para>
  421. </sect3>
  422. </sect2>
  423. <sect2 id="zend.search.lucene.query-language.grouping">
  424. <title>Gruppieren</title>
  425. <para>
  426. Java Lucene und <classname>Zend_Search_Lucene</classname> unterstützen die Verwendung
  427. von Klammern um Fälle zu gruppieren und Unterabfragen zu erstellen. Das kann nützlich
  428. sein wenn man die boolsche Operatoren für eine Abfrage kontrollieren will, oder
  429. unterschiedliche Abfragestile mischen will:
  430. </para>
  431. <programlisting language="querystring"><![CDATA[
  432. +(Framework OR Bibliothek) +php
  433. ]]></programlisting>
  434. <para>
  435. <classname>Zend_Search_Lucene</classname> unterstützt Unterabfragen von beliebigen
  436. Ebenen.
  437. </para>
  438. </sect2>
  439. <sect2 id="zend.search.lucene.query-language.field-grouping">
  440. <title>Felder gruppieren</title>
  441. <para>
  442. Lucene unterstützt auch die Verwendung von Klammern um mehrere Fälle in ein einzelnes
  443. Feld zu gruppieren.
  444. </para>
  445. <para>
  446. Um nach einem Titel zu suchen die sowohl das Wort "Rückkehr" und die Phrase "rosaroter
  447. Panther" kann die folgende Abfrage verwendet werden:
  448. </para>
  449. <programlisting language="querystring"><![CDATA[
  450. title:(+Rückkehr +"rosaroter Panther")
  451. ]]></programlisting>
  452. </sect2>
  453. <sect2 id="zend.search.lucene.query-language.escaping">
  454. <title>Escapen von speziellen Zeichen</title>
  455. <para>
  456. Lucene unterstützt das Escapen von speziellen Zeichen die in der Abfragesyntax verwendet
  457. werden. Die aktuelle Liste der speziellen Zeichen ist:
  458. </para>
  459. <para>
  460. + - &amp;&amp; || ! ( ) { } [ ] ^ " ~ * ? : \
  461. </para>
  462. <para>
  463. + und - in einem einzelnen Ausdruck werden automatisch als normale Zeichen behandelt.
  464. </para>
  465. <para>
  466. Für andere Instanzen von solchen Zeichen kann das \ vor jedem speziellen Zeichen
  467. verwendet werden der escaped werden soll. Um zum Beispiel nach (1+1):2 zu suchen kann
  468. die folgende Abfrage verwendet werden:
  469. </para>
  470. <programlisting language="querystring"><![CDATA[
  471. \(1\+1\)\:2
  472. ]]></programlisting>
  473. </sect2>
  474. </sect1>