22.03.2010, 21:08
|
|
Профессор
|
|
Регистрация: 15.12.2009
Сообщений: 742
|
|
UTF-8 b mySQL
Суть такая.
В Сервере, БД и таблицах ставлю кодировку UTF-8
Станица и файлы в uTF-8
При записи в БД кирилицы в uTF8 на выходе через phpMyAdmin в ячейках находятся крякозяблы. Но при считывании данных с БД и выдачи всайте все ок.
Помогает фича при коннекте к базе SET NAMES utf8 и крякозяблы пропадают. И отображается все по прежнему ок. Если данные опять же были занесены при этой команде. Старые при этойкоманде на выходе становятся крякозяблами как без нее в phpMyAdmin
Вопрос. Как избавится от этой команды? Что надо сделать с таблицами/базой/сервером, что бы в них хранилось корректный код UTF-8 символов, а не крякозяблы и не использовать эту команду?
Проблема. При экспортировании, если не устанавливать эту команду при занесении в базу, то выводятся крякозяблы...
__________________
Настоящий программист думает и осознает сам решение задачи, а не копирует другие мысли, не осознавая их (c)
Относись к человеку так же, как хотелось бы отношения к себе (с)
Все нужно там, где оно нужно, а все не нужно нигде (с) Gozar
B~Vladi: А кто такой JavaScript стрелок?! micscr: это тот, кто не jQuery танкист.
Программы становятся медленнее быстрее, чем компьютеры становятся быстрее (с) Никлаус Вирт
Последний раз редактировалось PeaceCoder, 22.03.2010 в 21:11.
|
|
22.03.2010, 22:09
|
|
Профессор
|
|
Регистрация: 15.12.2009
Сообщений: 742
|
|
Решение найдено, но оно не применимо со стороны клиента =(
http://dev.mysql.com/doc/refman/5.1/...onnection.html
Цитата:
|
With the mysql client, if you want to use a character set different from the default, you could explicitly execute SET NAMES every time you start up. However, to accomplish the same result more easily, you can add the --default-character-set option setting to your mysql command line or in your option file. For example, the following option file setting changes the three connection-related character set variables set to koi8r each time you invoke mysql:
|
__________________
Настоящий программист думает и осознает сам решение задачи, а не копирует другие мысли, не осознавая их (c)
Относись к человеку так же, как хотелось бы отношения к себе (с)
Все нужно там, где оно нужно, а все не нужно нигде (с) Gozar
B~Vladi: А кто такой JavaScript стрелок?! micscr: это тот, кто не jQuery танкист.
Программы становятся медленнее быстрее, чем компьютеры становятся быстрее (с) Никлаус Вирт
|
|
22.03.2010, 22:13
|
|
⊞ Развернуть
|
|
Регистрация: 11.01.2010
Сообщений: 1,810
|
|
Смотреть настройки сервера мускуля.
Можно в init connect прописать SET NAMES utf8.
Без доступа к настройкам мускуля никак.
|
|
23.03.2010, 00:38
|
|
Профессор
|
|
Регистрация: 15.12.2009
Сообщений: 742
|
|
Теперь вопрос в другом. В других базах такая же фигня? например в постадж или мсскл или оракл?
__________________
Настоящий программист думает и осознает сам решение задачи, а не копирует другие мысли, не осознавая их (c)
Относись к человеку так же, как хотелось бы отношения к себе (с)
Все нужно там, где оно нужно, а все не нужно нигде (с) Gozar
B~Vladi: А кто такой JavaScript стрелок?! micscr: это тот, кто не jQuery танкист.
Программы становятся медленнее быстрее, чем компьютеры становятся быстрее (с) Никлаус Вирт
|
|
27.03.2010, 08:13
|
|
Профессор
|
|
Регистрация: 10.09.2009
Сообщений: 1,576
|
|
Чтобы все корректно работало с кодировками в MySQL надо обязательно выставлять кодировку самого соединения:
mysql_query("SET NAMES utf8");
mysql_query("SET CHARACTER SET utf8" );
mysql_query("SET COLLATION_CONNECTION='utf8_general_ci'" );
т.е. надо учитывать:
- кодировку базы и таблиц
- кодировку соединения
- кодировку самих отправляемых/выводимых данных, т.е. в какой кодировке файл php.
|
|
27.03.2010, 18:20
|
|
Профессор
|
|
Регистрация: 15.12.2009
Сообщений: 742
|
|
Это ясно уже. Вопрос в другом. В других типах баз такая же проблема? или это такая "фича" мускуля?
__________________
Настоящий программист думает и осознает сам решение задачи, а не копирует другие мысли, не осознавая их (c)
Относись к человеку так же, как хотелось бы отношения к себе (с)
Все нужно там, где оно нужно, а все не нужно нигде (с) Gozar
B~Vladi: А кто такой JavaScript стрелок?! micscr: это тот, кто не jQuery танкист.
Программы становятся медленнее быстрее, чем компьютеры становятся быстрее (с) Никлаус Вирт
|
|
27.03.2010, 19:16
|
|
Профессор
|
|
Регистрация: 10.09.2009
Сообщений: 1,576
|
|
Особо с другими базами в вебе не работал, но посмотрел сейчас как в друпале сделан тонкий клиент к postgreSQL:
function db_connect($url) {
...
$connection = @pg_connect($conn_string);
...
pg_query($connection, "set client_encoding=\"UTF8\"");
}
т.е. походу тоже что-то подобное указывается.
|
|
|
|