Post
#1
|
|
|
Grupa: Zarejestrowani Postów: 34 Pomógł: 1 Dołączył: 25.12.2007 Ostrzeżenie: (0%)
|
Witam, przesiadam sie z MS SQL na MySQL i dopadaja mnie male problemy...
Kodowanie tabel mam ustawione na 'utf-8'. Nie wiem czemu zapytania SELECT zwracaja dopiero poprawnie dane (do PHP) po zastosowaniu wczesniej:
Do czego sluzy zatem NAMES (skoro mam zdefiniowane kodowanie w tabelach) ? Czy mozna ten parametr ustawic globalnie dla calej bazy aby nie ustawiac go przed kazdym SELECT ? (uwaga: NIE chodzi mi tu o caly serwer bazy) Drugie pytanie jakis sie nasuwa: jakie roznice w dzialaniu maja dwa ponizsze zapisy ?
I jeszcze jeden maly problem z sortowaniem w utf-8. Zauwazylem ze:
w przypadku gdy wyrazy zaczynaja sie np na 's' oraz 'ś' nie sortuje ich w kolejnosci 1) s; 2) ś a uznaje jako s-s i dopiero sortowanie odbywa sie po kolejnej literze... Da sie temu zaradzic? Zauwazylem w Query Managar'ze, ze to zapytan typu SELECT dodawane sa czesto na koncu pojedyncze znaki np:
Jaki skutek to odnosi w MySQL? |
|
|
|
![]() |
Post
#2
|
|
|
Grupa: Zarejestrowani Postów: 295 Pomógł: 7 Dołączył: 26.03.2004 Skąd: Opole Ostrzeżenie: (0%)
|
Dokładnie tak! Znowu - kodowanie które trafia do bazy może być inne niż w bazie (byleby w jakiś sposób potrafiła zapisać polskie znaki) trzeba tylko poinformować bazę czego ma się spodziewać w potoku danych - do tego służy set names. Baza przekonwertuje kodowanie na swoje własne tylko musi wiedzieć z jakim ma do czynienia na wejściu. Sama tego nie odgadnie. Nie zawsze domyślne ustawienia są bezkonfliktowe dlatego warto używać set names. W szczególności kiedy importujesz plik sql w określonym kodowaniu - musisz uprzedzić bazę o tym kodowaniu.
|
|
|
|
zietek NAMES / CHARACTER SET 4.01.2008, 09:54:29
sticker jakie masz collation na bazie i na tabeli? 4.01.2008, 10:55:53
Indeo Baza może mieć różne kodowania i może w nich popra... 4.01.2008, 11:18:16
zietek Dzieki za wyczepujaca odpowiedz:) Zapytam jeszcze ... 4.01.2008, 11:57:01
prond Jeszcze mała wskazówka do sortowania - jeżeli masz... 4.01.2008, 14:45:22 ![]() ![]() |
|
Aktualny czas: 28.12.2025 - 14:17 |