2011-01-06 6 views
1

Я пытаюсь написать простую клиентскую программу Java , которая использует koi8r как свой набор символов и продолжает отказываться.MySql Jdbc Connector - проблема локализации

Class.forName("com.mysql.jdbc.Driver"); 
Connection conn2 = DriverManager.getConnection ("jdbc:mysql://localhost:3306/test","root",null); 
Statement stmt = conn2.createStatement(); 
int result; 
result = stmt.executeUpdate("SET CHARACTER SET koi8r"); 

stmt = conn2.createStatement(); 
result = stmt.executeUpdate("DROP TABLE IF EXISTS װֱֱֲֳֹּ, t1, t2"); 
stmt.close(); 
assertEquals(0, result); 

Я получаю

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '???????, t1, t2' at line 1 

Когда я поместить эти команды в файл сценария и выполнять их с помощью MySql клиент работает нормально

SET CHARACTER SET koi8r 
DROP TABLE IF EXISTS װֱֱֲֳֹּ, t1, t2 

Я понюхал сеть, и я увидел разъем jdbc отправляет его с помощью ?????? к серверу, поэтому я думаю, что мне не хватает некоторых настроек для подключения. На самом деле я попробовал (setEncoding, setCharactersEncoding, setConncetionCollation ...), но все равно не удалось.

+0

Привет, я мало знаю о koi8r, но эта ссылка может помочь. http://www.fileformat.info/info/charset/KOI8-R/index.htm – Ankit

ответ

3

Вам необходимо указать драйвер JDBC, который он должен использовать для передачи символов по сети. Это означает, что по умолчанию используется стандартная кодировка платформы, которая в вашем случае, по-видимому, не UTF-8.

Вы можете сделать это, добавив следующие два параметра запроса в URL JDBC:

jdbc:mysql://localhost:3306/test?useUnicode=yes&characterEncoding=UTF-8 

Смотрите также the documentation.

Смежные вопросы