abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 10:44 | Zajímavý článek

    Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.

    Ladislav Hagara | Komentářů: 4
    dnes 01:00 | Nová verze

    Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.90 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.90 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    dnes 00:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) nová verze 2024.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | IT novinky

    Počítačová hra Tetris slaví 40 let. Alexej Pažitnov dokončil první hratelnou verzi 6. června 1984. Mezitím vznikla celá řada variant. Například Peklo nebo Nebe. Loni měl premiéru film Tetris.

    Ladislav Hagara | Komentářů: 10
    včera 10:44 | Nová verze

    MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.23.0. V přehledu novinek je vypíchnuta podpora dynamických USB zařízení nebo nové moduly openamp, tls a vfs.

    Ladislav Hagara | Komentářů: 0
    včera 10:22 | Nová verze

    Canonical vydal Ubuntu Core 24. Představení na YouTube. Nová verze Ubuntu Core vychází z Ubuntu 24.04 LTS a podporována bude 12 let. Ubuntu Core je určeno pro IoT (internet věcí) a vestavěné systémy.

    Ladislav Hagara | Komentářů: 2
    včera 01:00 | Nová verze Ladislav Hagara | Komentářů: 0
    4.6. 19:55 | IT novinky

    Intel na veletrhu Computex 2024 představil (YouTube) mimo jiné procesory Lunar Lake a Xeon 6.

    Ladislav Hagara | Komentářů: 0
    4.6. 13:44 | IT novinky

    Na blogu Raspberry Pi byl představen Raspberry Pi AI Kit určený vlastníkům Raspberry Pi 5, kteří na něm chtějí experimentovat se světem neuronových sítí, umělé inteligence a strojového učení. Jedná se o spolupráci se společností Hailo. Cena AI Kitu je 70 dolarů.

    Ladislav Hagara | Komentářů: 0
    4.6. 13:22 | Nová verze

    Byla vydána nová verze 14.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: mariadb (mysql) : invalid utf8 character string

    25.6.2020 08:27 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    mariadb (mysql) : invalid utf8 character string
    Přečteno: 1475×
    Zdravím,

    Mám sql příkaz, který uchovává v databázi obrázek a náhled. Po přechodu na novější verzi databáze dostávám warnings po vykonání příkazu k uložení - Invalid utf8 character string blabla.

    Pole k uložení dat NEMAJÍ určený typ ( ostatní pole a tabulka utf8-czech-ci ). Nevím co změnit, aby hláška zmizela ( a přes mega soubor s hláškou ).

    Vyšší utf asi nepomůže, protože to nejsou znaky. co ukládám, ale směsice - no prostě obrázek. Doposud používám fci mysqli::real-ecsape-string, ale ta nedokáže hlášce zabránit.

    Díky za každou dobrou radu.

    Řešení dotazu:


    Odpovědi

    25.6.2020 08:44 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Bolo by fajn spomenut verziu DB a ukazat strukturu tabulky + prikazu.

    Bez tychto detailov mi napada, ze to ide do nejakeho varcharu (ktory implikuje ten charset), a teda treba pouzit typ stlpca priamo urceny pre binarne data. Napriklad blob a jeho varianty, resp. varbinary.
    25.6.2020 09:31 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Ahoj.

    Verze serveru: 5.7.30-0ubuntu0.18.04.1 - (Ubuntu)

    struktura tabukky
     	# 	Název 	Typ 	Porovnávání 	Vlastnosti 	Nulový 	Výchozí 	Komentáře 	Další 	Operace
    	1 	IDPrimární 	varchar(64) 	utf8_czech_ci 		Ne 	Žádná 			
    	2 	Data 	mediumblob 			Ano 	NULL 			
    	3 	Thumb 	mediumblob 			Ne 	Žádná 			
    	4 	Note 	varchar(200) 	utf8_czech_ci 		Ne 	Žádná 			
    	5 	Mime 	varchar(30) 	utf8_czech_ci 		Ne 	Žádná 			
    	6 	ThumbMime 	varchar(30) 	utf8_czech_ci 		Ne 	Žádná 			
    	7 	Name 	varchar(128) 	utf8_czech_ci 		Ne 	Žádná 			
    Data a Thumb jsou blob, bez určení typu porovnávání.

    sqlko ti moc nenapoví, to jsem udělal v zápisu chyby. K serveru se dostane :
    Zpráva MySQL : Warning : ( 1300 ) Invalid utf8 character string: 'FFD8FF'
    INSERT INTO Images SET ID='0058a74348546954cde69c66a293d283', Note='', Mime='image/jpeg; charset=binary', ThumbMime='image/jpeg; charset=binary', Name='csc_2020_12_ZS+PL_str02.jpg', Data='����\0?JFIF......tam někde je ta chyba
    na Data i Thubs použiju před ulokládaním real_escape_string

    Ještě upozornění : obrázek ani náhled nevypadají poškozeně, zobrazí se bez hlášek ...
    25.6.2020 09:32 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Možná potom real_escape_string je tím problémem.
    25.6.2020 09:38 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Ano, vyzera to tak - mysql_real_escape_string neescapuje multibyte znaky => interpretuje literal v kontexte charsetu pripojenia; preto na rozdiel od mysql_escape_string ma aj druhy parameter. Vyskusaj teda mysql_escape_string.
    25.6.2020 09:41 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    To už jsem zkoušel, výsledek je stejný .. zapomněl jsem napsat.
    25.6.2020 09:48 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Potom mozno explicitne nastavit set_charset pri pouziti mysqli_real_escape_string?
    Řešení 1× (Milan Uhrák (tazatel))
    25.6.2020 11:54 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Píšu, že charset nic nemění. Nakonec jsem přes jiné otázky googlu našel funkci load_file, která zohlednuje blob pole, a nereflektuje charset ... trochu drbání levou rukou za pravým uchem, no, ale budiž.

    Uhrák
    Řešení 1× (Filip Jirsák)
    25.6.2020 13:40 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Binární data nemůžete vkládat jen tak v insertu, musíte je buď převést do bezpečné podoby base64 nebo hex anebo je vložit tou funkcí load_file. Koukněte na příklady do dokumentace k příslušné databázi. Taky koukněte, jak jsou ty bloby reprezentované při dumpu databáze.
    -- OldFrog
    20.7.2020 06:37 PetrHL | skóre: 17 | blog: petr_h | Neratovice
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Nepoužívejte utf8. Je to alias pro utf8mb3 a to nechcete. Vždy používejte utf8mb4.
    "Do, or do not. There is no 'try.'" -- Jedi Master Yoda | CQRLOG | CQRPROP | HamQTH | Domů

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.