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í
×
    včera 17:11 | IT novinky

    Společnost Jolla spustila kampaň na podporu svého nového telefonu Jolla Phone se Sailfish OS. Dodání je plánováno na první polovinu příštího roku. Pokud bude alespoň 2 000 zájemců. Záloha na telefon je 99 €. Cena telefonu v rámci kampaně je 499 €.

    Ladislav Hagara | Komentářů: 10
    včera 15:11 | IT novinky

    Netflix kupuje Warner Bros. včetně jejích filmových a televizních studií HBO Max a HBO. Za 72 miliard dolarů (asi 1,5 bilionu korun).

    Ladislav Hagara | Komentářů: 1
    včera 14:11 | IT novinky

    V Las Vegas dnes končí pětidenní konference AWS re:Invent 2025. Společnost Amazon Web Services (AWS) na ní představila celou řadu novinek. Vypíchnout lze 192jádrový CPU Graviton5 nebo AI chip Trainium3.

    Ladislav Hagara | Komentářů: 0
    včera 00:33 | Nová verze

    Firma Proxmox vydala novou serverovou distribuci Datacenter Manager ve verzi 1.0 (poznámky k vydání). Podobně jako Virtual Environment, Mail Gateway či Backup Server je založená na Debianu, k němuž přidává integraci ZFS, webové administrační rozhraní a další. Datacenter Manager je určený ke správě instalací právě ostatních distribucí Proxmox.

    |🇵🇸 | Komentářů: 6
    4.12. 23:44 | Nová verze

    Byla vydána nová verze 2.4.66 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 5 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    4.12. 14:00 | IT novinky

    Programovací jazyk JavaScript (Wikipedie) dnes slaví 30 let od svého oficiálního představení 4. prosince 1995.

    Ladislav Hagara | Komentářů: 0
    4.12. 04:22 | Bezpečnostní upozornění

    Byly zveřejněny informace o kritické zranitelnosti CVE-2025-55182 s CVSS 10.0 v React Server Components. Zranitelnost je opravena v Reactu 19.0.1, 19.1.2 a 19.2.1.

    Ladislav Hagara | Komentářů: 3
    4.12. 02:44 | Komunita

    Bylo rozhodnuto, že nejnovější Linux 6.18 je jádrem s prodlouženou upstream podporou (LTS). Ta je aktuálně plánována do prosince 2027. LTS jader je aktuálně šest: 5.10, 5.15, 6.1, 6.6, 6.12 a 6.18.

    Ladislav Hagara | Komentářů: 0
    4.12. 02:22 | Nová verze

    Byla vydána nová stabilní verze 3.23.0, tj. první z nové řady 3.23, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    3.12. 18:11 | Nová verze

    Byla vydána verze 6.0 webového aplikačního frameworku napsaného v Pythonu Django (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (47%)
     (19%)
     (18%)
     (22%)
     (15%)
     (25%)
     (16%)
     (18%)
    Celkem 432 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    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: 1128×
    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.