Я вставил символы cjk в мою таблицу. Почему select отображает их как символы . . 


Мы поможем в написании ваших работ!



ЗНАЕТЕ ЛИ ВЫ?

Я вставил символы cjk в мою таблицу. Почему select отображает их как символы . .



 

Эта проблема обычно из‑за установки в MySQL, который не соответствует параметрам настройки для прикладной программы или операционной системы. Имеются некоторые общие шаги для исправления этих типов проблем:

 

Определите версию MySQL. Используйте инструкцию SELECT VERSION(); для этого.

 

Проверьте, что база данных фактически использует желательный набор символов..

 

Люди часто думают, что набор символов пользователя всегда такой же, как набор символов сервера используемый для целей отображения. Однако, оба эти предположения неправильны. Вы можете удостовериться в этом, проверяя результат SHOW CREATE TABLE tablename, а лучше используя эту инструкцию:

 

SELECT character_set_name, collation_name FROM information_schema.columns

WHERE table_schema = your_database_name AND

table_name = your_table_name AND column_name = your_column_name;

 

Определите шестнадцатеричное значение символа или символов, которые не отображаются правильно..

 

Вы можете получать эту информацию для столбца column_name в таблице table_name, используя следующий запрос:

 

SELECT HEX(column_name)

FROM table_name;

 

3F кодирует символ?. Это означает, что? является символом, фактически сохраненным в столбце. Это наиболее часто случается из‑за проблемы при преобразовании специфического символа от Вашего набора символов пользователя до целевого набора символов.

 

Удостоверьтесь, что возможное путешествие туда и обратно, то есть когда Вы выбираете literal (или _introducer hexadecimal‑value), Вы получаете в результате именно literal.

 

Например, японский символ Katakana Pe (уГЪ') существует во всех CJK наборах символов, и имеет значение 0x30da. Чтобы проверять путешествие туда и обратно для этого символа, используйте этот запрос:

 

SELECT 'уГЪ' AS `уГЪ`; /* or SELECT _ucs2 0x30da; */

 

Если результат не такой, путешествие туда и обратно потерпело неудачу.

 

Удостоверьтесь, что проблема не с окном просмотра или другой прикладной программой, а именно с MySQL.

 

Используйте программу пользователя mysql (в Windows: mysql.exe), чтобы выполнить эту задачу. Если mysql отображает все правильно, но Ваша прикладная программа этого не делает, то проблема, вероятно, из‑за параметров настройки системы.

 

Чтобы выяснять, каковы Ваши параметры настройки, используйте инструкцию SHOW VARIABLES вывод которой должен походить на то, что показывается здесь:

 

mysql> SHOW VARIABLES LIKE 'char%';

+‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑+‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑+

| Variable_name | Value |

+‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑+‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑+

| character_set_client | utf8 |

| character_set_connection | utf8 |

| character_set_database | latin1 |

| character_set_filesystem | binary |

| character_set_results | utf8 |

| character_set_server | latin1 |

| character_set_system | utf8 |

| character_sets_dir | /usr/local/mysql/share/mysql/charsets/ |

+‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑+‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑‑+

8 rows in set (0.03 sec)

 

Это типичные параметры настройки набора символов для международно‑ориентируемого пользователя (обратите внимание на использование utf8 Unicode), связанного с сервером на западе (latin1 является набором символов западной Европы и значением по умолчанию для MySQL).

 

Хотя Unicode (обычно вариант utf8 на Unix и ucs2 в Windows) предпочтителен для Latin, это часто не то, что Ваши утилиты операционной системы поддерживают лучше всего. Много пользователей Windows находят, что набор символов Microsoft, типа cp932 для Japanese Windows, подходит им лучше.

 

Если Вы не можете управлять параметрами настройки сервера, и Вы понятия не имеете, каков Ваш основной компьютер, то пробуйте изменить набор символов на общий для страны, в которой Вы находитесь (euckr = Korea; gb2312 или gbk = People's Republic of China; big5 = Taiwan; sjis, ujis, cp932 или eucjpms = Japan; ucs2 or utf8 = где угодно). Обычно необходимо изменить только параметры настройки пользователя, результатов и подключение. Имеется простая инструкция, которая изменяется все три сразу: SET NAMES. Например:

 

SET NAMES 'big5';

 

Если только установка правильна, Вы можете делать это постоянным, редактируя my.cnf или my.ini. Например Вы могли бы добавлять строки, походящие на эти:

 

[mysqld]

character‑set‑server=big5

 

[client]

default‑character‑set=big5

 

Также возможно, что имеются проблемы с установкой конфигурации API, используемой в вашей прикладной программе.

 

Какие китайские (GB) наборы символов понимает MySQL?

 

MySQL поддерживает два общих варианта GB GB (Guojia Biaozhun или национального эталона) набора символов, которые являются официальными в КНР: gb2312 и gbk. Иногда люди пробуют вставлять символы gbk в gb2312, и это работает в большинстве случаев, потому что gbk является надмножеством gb2312, но в конечном счете они пробуют вставлять старые китайские символы, и это не работает (см. Глюк #16072).

 

Здесь мы пробуем разъяснять точно, какие символы являются законными в gb2312 или gbk в отношении официальных документов. Пожалуйста, проверьте эти ссылки перед сообщением об ошибках в gb2312 или gbk.

 

Для полной распечатки символов gb2312, упорядоченных согласно объединению gb2312_chinese_ci: http://d.udm.net/bar/~bar/charts/gb2312_chinese_ci.html.

 

MySQL gbk в действительности Microsoft code page 936. Это отличается от официального gbk для символов A1A4 (middle dot), A1AA (em dash), A6E0‑A6F5 и A8BB‑A8C0. Для получения распечатки различий см. http://recode.progiciels‑bpi.ca/showfile.html?name=dist/libiconv/gbk.h.

 

Для получения распечатки отображений gbk/Unicode см. http://www.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/WINDOWS/CP936.TXT.

 

Для получения распечатки MySQL‑символов gbk см. http://d.udm.net/bar/~bar/charts/gbk_chinese_ci.html.

 



Поделиться:


Последнее изменение этой страницы: 2021-01-14; просмотров: 70; Нарушение авторского права страницы; Мы поможем в написании вашей работы!

infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 18.222.179.186 (0.006 с.)