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 01:11 | Nová verze

    Byla vydána nová verze 1.8.0 svobodného multiplatformního softwaru pro konverzi video formátů HandBrake (Wikipedie). Přehled novinek v poznámkách k vydání na GitHubu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 21:55 | IT novinky

    Microsoft představil nové označení počítačů Copilot+. Dle oznámení se jedná se o počítače poskytující funkce umělé inteligence. Vedle CPU a GPU mají také NPU (Neural Processing Unit). Uvnitř představených Copilot+ notebooků běží ARM čipy Qualcomm Snapdragon X Elite nebo X Plus.

    Ladislav Hagara | Komentářů: 0
    včera 17:55 | Zajímavý článek

    Příspěvek na blogu Codean Labs rozebírá zranitelnost CVE-2024-4367 v PDF.js, tj. mj. prohlížeči PDF souborů ve Firefoxu. Při otevření útočníkem připraveného pdf souboru může být spuštěn libovolný kód v JavaScriptu. Vyřešeno ve Firefoxu 126.

    Ladislav Hagara | Komentářů: 1
    včera 12:55 | Nová verze

    Lazygit byl vydán ve verzi 0.42.0. Jedná se o TUI (Text User Interface) nadstavbu nad gitem.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | IT novinky

    K open source herní konzole Picopad přibyla (𝕏) vylepšená verze Picopad Pro s větším displejem, lepšími tlačítky a větší baterii. Na YouTube lze zhlédnout přednášku Picopad - open source herní konzole z LinuxDays 2023.

    Ladislav Hagara | Komentářů: 2
    17.5. 13:44 | Nová verze

    Byla vydána (𝕏) nová major verze 17 softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech GitLab (Wikipedie). Představení nových vlastností i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    17.5. 12:22 | Komunita

    Sovereign Tech Fund, tj. program financování otevřeného softwaru německým ministerstvem hospodářství a ochrany klimatu, podpoří vývoj FFmpeg částkou 157 580 eur. V listopadu loňského roku podpořil GNOME částkou 1 milion eur.

    Ladislav Hagara | Komentářů: 0
    17.5. 01:55 | Komunita

    24. září 2024 budou zveřejněny zdrojové kódy přehrávače Winamp.

    Ladislav Hagara | Komentářů: 12
    16.5. 23:33 | Nová verze

    Google Chrome 125 byl prohlášen za stabilní. Nejnovější stabilní verze 125.0.6422.60 přináší řadu oprav a vylepšení (YouTube). Podrobný přehled v poznámkách k vydání. Opraveno bylo 9 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 3
    16.5. 21:11 | Nová verze

    Textový editor Neovim byl vydán ve verzi 0.10 (𝕏). Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (79%)
     (5%)
     (8%)
     (7%)
    Celkem 402 hlasů
     Komentářů: 16, poslední 14.5. 11:05
    Rozcestník

    Dotaz: MySQL/MariaDB ROUND

    Jesus Jimenez avatar 16.10.2013 16:47 Jesus Jimenez | skóre: 29
    MySQL/MariaDB ROUND
    Přečteno: 1086×
    DD,

    tabulka t1, sloupce
    `id` autoincrement
    `c1` double
    `c2` double
    
    c1 = 605.5

    mysql/mariadb konzoli:
    select round(605.5);
    +--------------+
    | round(605.5) |
    +--------------+
    |          606 |
    +--------------+
    
    select round(c1) from t1;
    +--------------+
    | round(c1)    |
    +--------------+
    |          606 |
    +--------------+
    
    
    pridam proceduru
    CREATE DEFINER=`root`@`localhost` PROCEDURE `t1_update_c2` (IN `myid` int(11))
        MODIFIES SQL DATA
    BEGIN
    UPDATE `t1` SET `c2` = ROUND(`c1`) WHERE `id`=myid;
    END
    
    a pokud ji pres trigger zavolam, v c2 mam 605 - tedy zaokrouhleni DOLU

    spravne to funguje az pokud tu proceduru napisu takhle:
    CREATE DEFINER=`root`@`localhost` PROCEDURE `t1_update_c2` (IN `myid` int(11))
        MODIFIES SQL DATA
    BEGIN
    UPDATE `t1` SET `c2` = CAST(`c1` AS DECIMAL) WHERE `id`=myid;
    END
    
    delam neco spatne ja, nebo je to na bugreport?
    Doaenův zákon průtahů: Čím pomaleji pracuješ, tím méně naděláš chyb. -- Murphy

    Odpovědi

    17.10.2013 09:44 Dejv | skóre: 37 | blog: Jak ten blog nazvat ... ? | Ostrava
    Rozbalit Rozbalit vše Re: MySQL/MariaDB ROUND
    Tezko rict.
    mysql> create table t (id int, c1 double, c2 double);
    Query OK, 0 rows affected (0.03 sec)
    
    mysql> insert into t (id, c1) values (1, 605.5);
    Query OK, 1 row affected (0.10 sec)
    
    mysql> select * from t;
    +------+-------+------+
    | id   | c1    | c2   |
    +------+-------+------+
    |    1 | 605.5 | NULL |
    +------+-------+------+
    1 row in set (0.00 sec)
    
    mysql> select round(c1) from t where id = 1;
    +-----------+
    | round(c1) |
    +-----------+
    |       606 |
    +-----------+
    1 row in set (0.00 sec)
    
    mysql> update t set c2 = round(c1) where id = 1;
    Query OK, 1 row affected (0.03 sec)
    Rows matched: 1  Changed: 1  Warnings: 0
    
    mysql> select * from t where id = 1;
    +------+-------+------+
    | id   | c1    | c2   |
    +------+-------+------+
    |    1 | 605.5 |  606 |
    +------+-------+------+
    1 row in set (0.00 sec)
    
    
    D.
    Pevně věřím, že zkušenější uživatelé mě s mými nápady usměrní a pošlou tam, kam tyto nápady patří...
    Jesus Jimenez avatar 17.10.2013 10:38 Jesus Jimenez | skóre: 29
    Rozbalit Rozbalit vše Re: MySQL/MariaDB ROUND
    Nejde o ten jednoduchy update. Jde o round() v procedure. Zkuste tohle:
    DELIMITER //
    CREATE DEFINER=`root`@`localhost` PROCEDURE `round_double` (IN `cislo` double)
    BEGIN
    SELECT ROUND(`cislo`);
    END //
    DELIMITER ;
    
    call round_double(6.5);
    
    vrati 6
    DELIMITER //
    CREATE DEFINER=`root`@`localhost` PROCEDURE `round_decimal` (IN `cislo` decimal(10, 2))
    BEGIN
    SELECT ROUND(`cislo`);
    END //
    DELIMITER ;
    
    call round_decimal(6.5);
    
    vrati 7

    cili typy double, float v procedure zaokrouhli spatne, typ decimal spravne. Ale JENOM v procedure.
    Doaenův zákon průtahů: Čím pomaleji pracuješ, tím méně naděláš chyb. -- Murphy
    17.10.2013 11:30 Kit
    Rozbalit Rozbalit vše Re: MySQL/MariaDB ROUND
    Funguje to tak, že se double a float zaokrouhlí na SUDÉ. Je to jedno z pravidel zaokrouhlování. Decimal se zaokrouhlí nahoru.

    Pokud se číslo 6.5 nachází ve výrazu jako konstanta, databáze ji považuje za typ DECIMAL a dle tvého se zaokrouhlí správně. Předáním do procedury je však přetypována na double a změní se tím zaokrouhlovací pravidla.
    Jesus Jimenez avatar 17.10.2013 12:27 Jesus Jimenez | skóre: 29
    Rozbalit Rozbalit vše Re: MySQL/MariaDB ROUND
    jj, je to v dokumentaci. je to kazdopadne debilni pravidlo.
    Doaenův zákon průtahů: Čím pomaleji pracuješ, tím méně naděláš chyb. -- Murphy
    17.10.2013 12:53 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: MySQL/MariaDB ROUND
    Holt čísla s plovoucí desetinnou čárkou nejsou to samé co reální čísla.
    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.