abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:33 | Komunita

    Po Canonicalu oznámilo také SUSE, že bude podporovat a distribuovat toolkit NVIDIA CUDA (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Nová verze

    Laboratoře CZ.NIC vydaly novou verzi 4.27.0 aplikace Datovka, tj. svobodné multiplatformní desktopové aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi. Přidány byly funkce pro přerazítkování datových zpráv systémem ISDS. Uživatel muže zvolit zprávy, jejichž časová razítka má aplikace sledovat. Aplikace jej upozorní na časová razítka, která lze přerazítkovat. Uživatel pak může

    … více »
    Ladislav Hagara | Komentářů: 0
    dnes 12:00 | IT novinky

    Bylo představeno all-in-one PC aneb mechanická podsvícená klávesnice s Raspberry Pi 5 uvnitř Raspberry Pi 500+. S 256 GB Raspberry Pi SSD a 16 GB RAM za 200 dolarů.

    Ladislav Hagara | Komentářů: 8
    včera 21:11 | IT novinky

    Google, potažmo YouTube umožní návrat tvůrcům, kteří byli zablokováni kvůli údajnému šíření dezinformací souvisejících s COVID-19 a volbami. Tvůrci teď mohou požádat o navrácení přístupu. Společnost Alphabet v této souvislosti uvedla, že zákazy byly uděleny kvůli tlaku tehdejší Bidenovy administrativy.

    karkar | Komentářů: 17
    včera 18:33 | Zajímavý článek

    Vývojári z distribúcie Artix, ktorá je postavená na Arch Linuxe, alebo skôr jeho forkom, už skôr prešli na Open-RC init systém, stále však niektoré projekty ako GNOME boli závislé na systemd. Teraz pretiekol pohár trpezlivosti a počnúc GNOME 49, kvôli ktorému komponenta gnome-session je úplne závislá na systemd-init, padlo rozhodnutie na odstránenie GNOME z repozitárov Artixu. Táto zmena sa podľa všetkého týka viac než 90 distribúcií, ktoré tiež nepoužívajú systemd. Viac v príspevku na DistroWatch.

    lukve | Komentářů: 8
    včera 17:33 | IT novinky

    Magazín IEEE Spectrum opět po roce publikoval svůj žebříček programovacích jazyků. Vedou Python, Java, C++, SQL a C#.

    Ladislav Hagara | Komentářů: 5
    včera 15:11 | Komunita

    Repozitáře pro spolupráci v rámci projektu Fedora se přesunou z Pagure na nově vzniklý Fedora Forge. Ten stejně jako třeba Codeberg běží na softwaru Forgejo, které bylo už před časem vybráno jako náhrada za Pagure. Pagure pochází z dílny Fedory, ale mimo ni se příliš neuchytil. Jeho vývoj a údržba byly náročné a Fedora se rozhodla jít cestou úspěšnějšího projektu, který má větší základnu přispěvatelů.

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

    Byla vydána (𝕏) nová verze 2025.3 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í na blogu.

    Ladislav Hagara | Komentářů: 0
    23.9. 12:33 | IT novinky

    V IT4Innovations národním superpočítačovém centru byl dnes slavnostně spuštěn první český kvantový počítač VLQ disponující 24 fyzickými qubity s unikátní hvězdicovou topologií. Systém dodala společnost IQM Quantum Computers a jeho celková pořizovací cena činila přibližně 125 milionů korun.

    Ladislav Hagara | Komentářů: 31
    23.9. 12:22 | IT novinky

    Výrobce čipů Nvidia chce investovat až 100 miliard dolarů (přes dva biliony Kč) do společnosti zaměřené na umělou inteligenci OpenAI. Firmy o tom informují v tiskové zprávě. Oznámené partnerství přichází v době, kdy se mezi technologickými giganty a start-upy zostřuje konkurence o zajištění přístupu k energii a čipům potřebným pro rozvoj umělé inteligence (AI).

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (42%)
     (52%)
     (10%)
     (11%)
     (12%)
     (11%)
     (18%)
     (11%)
     (14%)
    Celkem 91 hlasů
     Komentářů: 9, poslední včera 17:28
    Rozcestník

    Dotaz: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext

    5.8.2010 15:19 jben | skóre: 4
    Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext
    Přečteno: 2359×
    Podařilo se mi zprovoznit zobrazování dat z MSSQL serveru (Server2003, SQL2005) přes Freetds 0.82 do Apache/2.2.3 a PHP 5.1.6. na Centos5/2.6.18 Nedaří se mi překonat 2 překážky: 1. nesprávné kódování zobrazených dat nastavení: -MSSQL - UTF-8/Czech_CI_AS -freetds.conf - tds version=8.0 a client charset=UTF-8 -php.ini - default_charset = "utf-8" a mssql.charset = "utf-8" -httpd.conf - AddDefaultCharset Off, -*.php - meta ...charset=utf-8 Asi mi něco uniká, ale prezentovaná data jsou stále ve Windows-1250.

    2. zobrazení pole poznámky (ntext) příklad: $vysledek2 = mssql_query("SELECT TOP 20 ID,SkupZbo,RegCis,Poznamka ....."); while ($zaznam2 = mssql_fetch_array($vysledek2) ): ... Dotaz funguje jen pokud tam není pole Poznamka, které je typu ntext. Jinak vznikne problém s kódováním nebo collation. Předpokládám, že bude nutná nějaká konverze, jen nevím jak se obdobné řeší.

    Můžete někdo poradit, jak oba problémy překonat nebo nasměrovat na obdobné řešení. Předem dík.

    Odpovědi

    5.8.2010 15:26 jben | skóre: 4
    Rozbalit Rozbalit vše Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava

    Tentokrát snad přehledněji.

    Podařilo se mi zprovoznit zobrazování dat z MSSQL serveru (Server2003, SQL2005) přes Freetds 0.82 do Apache/2.2.3 a PHP 5.1.6. na Centos5/2.6.18

    Nedaří se mi překonat 2 překážky:

    1. nesprávné kódování zobrazených dat nastavení:
    -MSSQL - UTF-8/Czech_CI_AS
    -freetds.conf - tds version=8.0 a client charset=UTF-8
    -php.ini - default_charset = "utf-8" a mssql.charset = "utf-8"
    -httpd.conf - AddDefaultCharset Off
    -*.php - meta ...charset=utf-8

    Asi mi něco uniká, ale prezentovaná data jsou stále ve Windows-1250.

    2. zobrazení pole poznámky (ntext) příklad:

    $vysledek2 = mssql_query("SELECT TOP 20 ID,SkupZbo,RegCis,Poznamka .....");
    while ($zaznam2 = mssql_fetch_array($vysledek2) ): ...

    Dotaz funguje jen pokud tam není pole Poznamka, které je typu ntext. Jinak vznikne problém s kódováním nebo collation. Předpokládám, že bude nutná nějaká konverze, jen nevím jak se obdobné řeší.

    Můžete někdo poradit, jak oba problémy překonat nebo nasměrovat na obdobné řešení. Předem dík.

    5.8.2010 16:36 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava
    Zkuste:
    mssql.charset="UTF-8", případně v php kódu ini_set("mssql.charset", "UTF-8");.
    (UTF-8 velkými písmeny…)
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    5.8.2010 17:16 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava
    Ale abych to doplnil, tak ještě jednou.
    Nepamatuji si to přesně (už je to dýl co jsme s tím dělal a nemám nyní možnost se na to juknout), ale mělo by to být tak jak popisuji v následujícím komentovaném příkladu:
    /* 
     nastavit tyto volby nebo je nastavit v php.ini -------------------
    */
    ini_set( 'mssql.charset',   'UTF-8' ); //charset
    
    /*
     Pokude nebude následující nastaveno, tak texty se normálně oříznou, bez nějaké chyby či varování.
     Jestli se nepletu, tak nenastaveno (či '-1'), znamená jen 4KiB.
    */
    ini_set( 'mssql.textlimit', '65536' ); 
    ini_set( 'mssql.textsize',  '65536' ); 
    
    /*
     ¿Konverze datumů?
    */
    //ini_set( 'mssql.datetimeconvert',  '1 nebo 0' );
    /*
     ------------------------------------------------------------------
    */
    
    $con = mssql_connect(....);
    
    @mssql_query("SET TEXTSIZE 65536", $con); //nastavit před selectem, postačuje 1× za sezení - možná nebude nutné
                                              //asi je to ekvivalentem 'mssql.textsize' - nepamatuji si :(
    
    
    //Pravděpodobně bude nutné u SQL dotazu přetypovat NTEXT a NVARCHAR např.:
    $rs = mssql_query('SELECT TOP 20 ID,SkupZbo,RegCis,CAST(Poznamka AS TEXT)…');
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    5.8.2010 21:35 jben | skóre: 4
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava

    Nápady jsem vyzkoušel, ale úspěch byl jen částečný:

    ad.1. kódování
    • žádná z uvedených možností v kódování nic nezměnila
    • mám spíš pocit, že problém bude někde u freetds, ale nevím , jak to ověřit
    ad.2. ntext
    • změna byla úspěšná, jen jsem to musel trochu upravit:
      $rs = mssql_query('SELECT TOP 20 ID,SkupZbo,RegCis,CAST(Poznamka AS TEXT) AS Poznamka …');
    • původní návrh sice odstranil chybu dotazu, ale nic se nevypsalo

    Přesto dík za pomoc, budu hledat dál.

    6.8.2010 07:44 jben | skóre: 4
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava

    Ještě doplním poslední zjištění k chybě kódování:

    • pokud spustím stejný dotaz přes tsql na konzoli, tak je kódování správné
    • zjistil jsem, že freetds používá freetds.conf ze dvou umístění, podle toho, kdo freetds volá
      • pokud spustím tsql na konzoli, tak použije /etc/freetds.conf
      • pokud spojení inicializuje php, tak použije /usr/local/etc/freetds.conf
      • nicméně oba jsou stejné, takže by to vadit nemuselo, ale je to divné
      • důvod jsem zatím neodhalil, ale může to souviset z různými pokusy prováděnými při zprovozňování mssql-freetds-php komunikace
    6.8.2010 09:10 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava
    Ad. 'AS' - to jsem už nedopisoval, to jsem nechal na Vás…, důležité je to CAST-ování
    Ad. kódování, jste si jistý, že to není v utf-ku, a že chyba není jen v zobrazení?
    Lze se na tu stránku někde podívat?, nebo wget-em stáhněte tu stránku a hoďte ji sem.

    Zkoušel jste variantu:
    ini_set( 'mssql.charset',   'UTF-8' );// nebo/a v php.ini 
    ini_set( 'mssql.textlimit', '65536' );// nebo/a v php.ini 
    ini_set( 'mssql.textsize',  '65536' );// nebo/a v php.ini 
    $con = mssql_connect(....);
    @mssql_query("SET TEXTSIZE 65536", $con); 
    $rs = mssql_query('SELECT TOP 20 ID,SkupZbo,RegCis,Poznamka…');//bez CAST
    
    ?
    Za předpokladu že texty nejsou dlouhé, jinak zvýšit hodnotu 65536, buď to musí být větší než maximální délka textu, nebo 2× větší než maximální délka textu… „či ja vjem“ :)
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    6.8.2010 23:48 jben | skóre: 4
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava
    Příloha:

    Takže úpravy nastavení ini_... nemají žádný vliv, v php.ini už to je zapsáno od minule.

    S tou poznámkou mi to jinak než s CAST nefunguje.

    Ohledně skutečného kódování stránky si samozřejmě jistý na 100% nejsem, ale v rámci svých možností jsem jinou možnost nezjistil. Stránka není nikde vystavená, je to jen na intranetu, přes wget neumím stránku sestavit tak, aby obsahovala i data z db.

    Připojuji něco ze stránky, kterou jsem uložil ve Voknech z FF a ručně pročistil, je tam jen ta část, kolem dat z databáze- ty jsou v té tabulce.

    Jelikož se jedná pouze o dvě pole, ve kterých jsou problematická data, tak jdu hledat něco pro překódování jen konkrétních polí před zobrazením, třeba to bude stačit.

    K tomu kódování mě ještě napadá možnost, že jsem nějak nesprávně zkompiloval php s freetds, jen teď nevím, jak to oveřit.

    Opět dík za trpělivost a rady.

    7.8.2010 00:11 jben | skóre: 4
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava

    Kódování jsem nakonec vyřešil překódováním až v php

    echo "...".$zaznam2["RegCis"]."...";
    echo "...".iconv('CP1250', 'UTF-8', $zaznam2['Nazev1'])."...";
    echo "...".iconv('CP1250', 'UTF-8', $zaznam2['Poznamka'])."...";

    Určitě to není ideální řešení, ale momentálně to splňuje účel, takže to zatím dál zkoumat nebudu.

    9.8.2010 09:43 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Linux, PHP, Apache - MSSQL, kódování a zobrazení ntext - oprava
    Když to funguje… :)
    Ono to má možná logiku, ten CAST převede ten text asi do default kódování serveru M$SQL, což bude asi 'Windows-1250' a už to tak zůstane.
    Nějak mi stále uniká práce se znakovýma sadama u M$SQL a u M$ obecně :(, ale taky to zkoumat nebudu :).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    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.