Vydělávej až 160.000 Kč měsíčně! Akreditované rekvalifikační kurzy s garancí práce od 0 Kč. Více informací.
Hledáme nové posily do ITnetwork týmu. Podívej se na volné pozice a přidej se do nejagilnější firmy na trhu - Více informací.
Avatar
jenda
Člen
Avatar
jenda:22.11.2017 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.11.2017 9:23
Avatar
Odpovídá na jenda
Michal Šmahel:22.11.2017 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.11.2017 15:31
Nahoru Odpovědět
22.11.2017 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.11.2017 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.11.2017 16:36
Avatar
jenda
Člen
Avatar
Odpovídá na Michal Šmahel
jenda:22.11.2017 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.11.2017 17:19
Avatar
Odpovídá na jenda
Michal Šmahel:22.11.2017 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.11.2017 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.11.2017 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.11.2017 19:59
Avatar
Odpovídá na jenda
Michal Šmahel:22.11.2017 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.11.2017 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.11.2017 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.11.2017 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.