[ZF-10089] Zend_Log
[zend.git] / documentation / manual / zh / module_specs / Zend_Search_Lucene-Charset.xml
blobaebd447614c9ae41313deb3714c5aef53c66fe9e
1 <sect1 id="zend.search.lucene.charset">
2     <title>字符集</title>
4     <sect2 id="zend.search.lucene.charset.description">
5         <title> UTF-8 和单字节字符集支持</title>
7         <para>
8             被设计于工作在 UTF-8 字符集下。索引文件在 Java 的"modified UTF-8 encoding"编码下保存文件。Zend_Search_Lucene 内核完全支持它,只有一处例外。
9             <footnote>
10                <para>
11                    Zend_Search_Lucene 只支持基本多语言平面(Basic Multilingual Plane, BMP)字符集(从 0x0000 到 0xFFFF),不支持辅助字符集(supplementary characters)(那些代码指针大于 0xFFFF 的字符)
12                </para>
13                <para>
14                    Java 2 通过一对两个 16 位字符的值来表示这些字符,第一个来自高半代理(high-surrogates)区(0xD800-0xDBFF),第二个来自低半代理(low- surrogates)区(0xDC00-0xDFFF)。它们将常用的 UTF-8 字符编码为 6 个字节。而标准的 UTF-8 通过四个字节来表示附加的字符。
15                </para>
16                <para>
17                   (译注:有关信息请参考 Unicode 标准。可能大家更想知道的是 BMP 中是否支持中文,答案是肯定的。事实上 BMP 中 CJK 字符集所占的比例最高。)
18                </para>
19             </footnote>
21         </para>
23         <para>
24             然而,各类文本和查询分析程序使用 ctype_alpha() 来进行文本和查询的记号化处理。而 ctype_alpha() 不支持 UTF-8,在不久的将来需要被替换为别的什么机制。
25         </para>
27         <para>
28             在此之前我们强烈推荐将你的数据转化成 ASCII 表示
29             <footnote>
30                <para>
31                    如果数据包含非 ASCII 字符或者来自 UTF-8。
32                </para>
33             </footnote>
34             (不管是存储原始文档,或者进行搜索):
35         </para>
37         <programlisting role="php"><![CDATA[<?php
38 $doc = new Zend_Search_Lucene_Document();
39 ...
40 $docText = iconv('ISO-8859-1', 'ASCII//TRANSLIT', $docText);
41 $doc->addField(Zend_Search_Lucene_Field::UnStored('contents', $docText));
43 ...
45 $query = iconv('', 'ASCII//TRANSLIT', $query);
46 $hits = $index->find($query);
47 ?>]]></programlisting>
49     </sect2>
50 </sect1>
52 <!--
53 vim:se ts=4 sw=4 et:
54 -->