1

私の data-config.xml は次のようになります。ファイルのエンコーディングは、BOM 付きの UTF-8 です。

<?xml version="1.0" encoding="UTF-8"?>
<dataConfig>
  <dataSource type="JdbcDataSource" 
              driver="com.mysql.jdbc.Driver"
              url="jdbc:mysql://192.168.0.2/dasaran_old" 
              user="root" 
              password=""
              encoding="UTF-8"/>
  <document>
    <entity name="user" 
            query="SELECT CONCAT_WS('_', 1, u.`id`) AS id, u.`id` AS entity_id, 1 AS entity_type, fullname AS title, CONCAT_WS(' ', 'Դպրոց՝ ', s.title, 'դաս.՝', cl.title) AS description FROM das_user u INNER JOIN das_ref_student_to_class_to_school sts ON u.id = sts.student_id INNER JOIN das_school s ON sts.school_id = s.id INNER JOIN das_classes cl ON sts.class_id = cl.id WHERE u.role = 'student'">
    </entity>
  </document>
</dataConfig>

MySQL から抽出した Unicode データは問題ありません。ただし、クエリ内の Unicode 文字は、Solr インデックスに Unicode として挿入されていません。

このようなドキュメントを取得しています。

<doc>
<str name="description">?????? 65 ???.? 5-1</str>
<int name="entity_id">18126</int>
<int name="entity_type">1</int>
<str name="general">Ռուբեն Վարդանյան Արմենի</str>
<str name="id">[B@1bc6e3ce</str>
<str name="title">Ռուբեն Վարդանյան Արմենի</str>
</doc>
4

1 に答える 1

0

data-config.xml のエンコーディングは、jdbc 接続で使用されるエンコーディングとは何の関係もないと思います。それを URL パラメータとして指定する必要があります。この質問の詳細を参照してください。

パラメータは次のとおりです。

jdbc:mysql://localhost:3306/administer?characterEncoding=utf8
于 2012-08-14T15:51:35.903 に答える