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 13:33 | Nová verze

    Vyšlo Pharo 12.0, programovací jazyk a vývojové prostředí s řadou pokročilých vlastností. Krom tradiční nadílky oprav přináší nový systém správy ladících bodů, nový způsob definice tříd, prostor pro objekty, které nemusí procházet GC a mnoho dalšího.

    Pavel Křivánek | Komentářů: 0
    dnes 04:55 | Zajímavý software

    Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.

    Ladislav Hagara | Komentářů: 21
    včera 17:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.

    Ladislav Hagara | Komentářů: 13
    včera 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

    Ladislav Hagara | Komentářů: 2
    včera 13:22 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

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

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

    Ladislav Hagara | Komentářů: 0
    včera 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

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

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    včera 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    24.4. 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 14
    KDE Plasma 6
     (73%)
     (9%)
     (2%)
     (16%)
    Celkem 789 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    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: 1083×
    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.