Získej svůj iPhone v nové soutěži! Získej svůj iPhone v nové soutěži!
Nová překladatelská soutěž ITnetwork.cz o telefon iPhone, sluchátka Beats a další věcné ceny za 4 hodiny práce.
Přidej si svou IT školu do profilu a najdi spolužáky zde na síti :)

Diskuze: SQL Character set

Ostatní jazyky SQL SQL a databáze SQL Character set

Aktivity (1)
Avatar
jenda
Člen
Avatar
jenda:22. listopadu 9:23

Mám potíž se změnou COLLATE. Pokud udělám sql dotaz v phpmyadmin, tak to proběhne v pořádku. Pokud to samé pustím přes PHP, tak to vyhodí chybu: Warning: PDO::prepare(): SQLSTATE[42000]: Syntax error or access violation: 1253 COLLATION 'utf8mb4_gene­ral_ci' is not valid for CHARACTER SET 'binary' in C:\xampp\htdoc­s\Slovnik7\Db­.php on line 60

Zkusil jsem před dotaz vložit i Db::query('SET NAMES utf8mb4');, ale ani to nepomohlo. Kde mám co změnit, abych mohl ten utf8mb4_general_ci použít? Poradíte? Díky

Db::query('SET NAMES utf8mb4');
        $slovicka = Db::queryAll('

                SELECT `cesky`, `madarsky`, `vyslovnost`
                FROM `madarska_slovicka`, `ceska_slovicka`, `vazebni_tabulka_slovicka`
                WHERE (`ID_madarsky` = `ID_madarsky_vazba` AND `ID_cesky_vazba` = `ID_cesky` AND `cesky` LIKE ? COLLATE utf8mb4_general_ci )
                ORDER BY `cesky`
                LIMIT 30
            ', $heslo1);

\---

 
Odpovědět 22. listopadu 9:23
Avatar
Odpovídá na jenda
Michal Šmahel:22. listopadu 15:31

Ahoj, to tvé kódování (CHARACTER SET) je nějaké divoké. Jelikož chceš nastavit porovnání (COLLATE) na nějaký typ UTF-8, chtělo by to i odpovídající kódování.

Nevím, jak to máš vymyšlené, ale lehce to zavání chybným návrhem. Pokud v tabulce ještě nejsou data, doporučil bych změnu kódování a následnou změnu porovnávání (což požaduješ).

Editováno 22. listopadu 15:31
Nahoru Odpovědět 22. listopadu 15:31
Nejdůležitější je motivace, ovšem musí být doprovázena činy.
Avatar
jenda
Člen
Avatar
Odpovídá na Michal Šmahel
jenda:22. listopadu 16:36

Nevím, zda jsem byl pochopen. Databáze je naplněna. Při spuštění dotazu z phpmyadmin konzole to vrací korektní výsledky. Pouze když to pustím ze svého PHP skriptu, tak dojde k té chybě. Standardně používám porovnávání utf8_bin kvůli přesnému vyhledávání češtiny. (tak je to nastaveno na tabulce). Nicméně pro určitý typ výsledku potřebuji porovnávání utf8mb4.

Návrh mohu mít špatně, zase tak moc tomu nerozumím.

Nicméně se domnívám, že dotaz zní - jak mu nastavit ten character set jinak, než binary? Případně neskrývá se za onou hláškou něco jiného?

 
Nahoru Odpovědět 22. listopadu 16:36
Avatar
jenda
Člen
Avatar
Odpovídá na Michal Šmahel
jenda:22. listopadu 17:19

Tak když to zadám natvrdo před hledaný text, tak to funguje:

SELECT `cesky`, `madarsky`, `vyslovnost`
                FROM `madarska_slovicka`, `ceska_slovicka`, `vazebni_tabulka_slovicka`
                WHERE (`ID_madarsky` = `ID_madarsky_vazba` AND `ID_cesky_vazba` = `ID_cesky` AND `cesky` LIKE _utf8mb4"rec" COLLATE utf8mb4_general_ci)
                ORDER BY `cesky`
                LIMIT 30

Tedy to krásně najde jak "rec", tak i "řeč".

Jenže já tam potřebuji dosazovat proměnnou. A když tam dám místo řetězce tu proměnnou, tak to hlásí chybu syntaxe

$slovicka = Db::queryAll('

                SELECT `cesky`, `madarsky`, `vyslovnost`
                FROM `madarska_slovicka`, `ceska_slovicka`, `vazebni_tabulka_slovicka`
                WHERE (`ID_madarsky` = `ID_madarsky_vazba` AND `ID_cesky_vazba` = `ID_cesky` AND `cesky` LIKE _utf8mb4? COLLATE utf8mb4_general_ci)
                ORDER BY `cesky`
                LIMIT 30
            ', $heslo1);

Poradíte prosím, jak to s tím otazníkem zadat správně?

 
Nahoru Odpovědět 22. listopadu 17:19
Avatar
Odpovídá na jenda
Michal Šmahel:22. listopadu 18:55

Tady nastává problém s těmi daty. Když se změní kódování, může se z textů stát "rozsypaný čaj," což není přípustné. Spusť si v PHPMyAdmin tento dotaz:

SELECT CCSA.character_set_name FROM information_schema.`TABLES` T,
       information_schema.`COLLATION_CHARACTER_SET_APPLICABILITY` CCSA
WHERE CCSA.collation_name = T.table_collation
  AND T.table_schema = "nazev-databaze"
  AND T.table_name = "nazev-tabulky";

Myslím si, že ti to vrátí právě "binary." Je to kvůli tomu, že jsi kódování nenastavil již při vytváření tabulky/databáze a výchozím je právě "binary."

Co se týče řešení, můžeš zkusit zálohovat danou tabulku a pokusit se převést jednotlivé sloupce na požadované kódování "utf8." Nějaké čtení je například tady. Ale každopádně bez zálohy nic nezkoušet.

Nahoru Odpovědět 22. listopadu 18:55
Nejdůležitější je motivace, ovšem musí být doprovázena činy.
Avatar
jenda
Člen
Avatar
Odpovídá na Michal Šmahel
jenda:22. listopadu 19:59

Díky.
Výsledek je character_set_name: utf8

Ale nemyslím si, že by se to rozsypalo, když to funguje i v PHP. Jde jen o to, jak do toho dostat ty otazníky místo proměnné místo přímého textu.

Když napíšu přímo

LIKE _utf8mb4"rec" COLLATE utf8mb4_general_ci

, tak to funguje. Já potřebuji ten řetězec "řeč" nahradit proměnnou. To se dělá otazníkem a následně uvedenou proměnnou. Jenže když napíšu:
LIKE _utf8mb4"?" COLLATE utf8mb4_general_ci nebo
LIKE _utf8mb4(?) COLLATE utf8mb4_general_ci
tak to nefunguje a hodí chybu syntaxe.

Když to napíšu do proměnné $retezec = "_utf8mb4$promenna" nebo
$retezec = "_utf8mb4'$pro­menna'" nebo
$retezec = '_utf8mb4"'.$pro­menna.'"'
tak to vyhledá celý řetězec a to _utf8mb4 to ignoruje ..

Takže jak jinak to zapsat?

 
Nahoru Odpovědět 22. listopadu 19:59
Avatar
Odpovídá na jenda
Michal Šmahel:22. listopadu 23:24

Mně šlo o to, aby sis opravil tu tabulku a na data se mohl dotazovat běžným způsobem.

Pokud trváš na svém řešení, můžeš využít CONCAT(), který spojuje části dotazu.

-- Nemusí fungovat (viz dále)
... CONCAT(_utf8mb4, ?) ...

Toto tvrzení nemám podložené, píši již z telefonu a nemohu to vyzkoušet.

Nahoru Odpovědět 22. listopadu 23:24
Nejdůležitější je motivace, ovšem musí být doprovázena činy.
Avatar
jenda
Člen
Avatar
Odpovídá na Michal Šmahel
jenda:23. listopadu 9:00

Díky, ale cesta to nebyla správná. Správné řešení je popsané na https://stackoverflow.com/…ed-statement

Akceptované řešení
+5 Zkušeností
Řešení problému
 
Nahoru Odpovědět 23. listopadu 9:00
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 8 zpráv z 8.