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 15:22 | Nová verze

    Tento týden byla vydána nová verze 1.52 webového prohlížeče Brave (Wikipedie, GitHub). Postavena je na Chromiu 114. Z novinek lze vypíchnout možnost povolit vertikální karty (vertical tabs). Také bylo představeno Brave Search API k vyhledávači Brave Search.

    Ladislav Hagara | Komentářů: 0
    včera 19:55 | Komunita

    Matthias Clasen z Red Hatu oznámil v diskusním listu vývojářů Fedora Linuxu, že tým Red Hat Display Systems se zaměří na Wayland a podporu HDR na Linuxu a přestane spravovat RPM balíčky pro LibreOffice. V další major verzi RHELu už LibreOffice nebude. Pokud se nenajde správce balíčků pro Fedora Linux, zůstane pouze LibreOffice ve Flatpaku.

    Ladislav Hagara | Komentářů: 19
    včera 17:33 | IT novinky

    Na Steamu lze získat zdarma počítačovou hru Tell Me Why (ProtonDB). Na Epic Games Storu počítačovou hru Midnight Ghost Hunt (ProtonDB).

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

    Společnost Meta představila (YouTube) brýle pro virtuální realitu Meta Quest 3. V prodeji budou na podzim a stát budou od 499,99 dolarů.

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

    Byla vydána nová verze 2.41.0 distribuovaného systému správy verzí Git. Přispělo 95 vývojářů, z toho 29 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

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

    Organizace Apache Software Foundation (ASF) vydala verzi 18 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

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

    Byla vydána verze 1.70.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example. Jako reakce na rostoucí obavy z vlivu korporací na vývoj Rustu a předložený návrh restriktivních zásad používání ochranných známek Rustu, byl nedávno představen komunitní fork Rustu se 100 % méně byrokracie: Crab (CrabLang).

    Ladislav Hagara | Komentářů: 8
    1.6. 21:55 | Zajímavý článek

    Oliver Smith z Canonicalu shrnuje základní vlastnosti „neměnné“ distribuce Ubuntu Core také ve srovnání s protějšky Chrome OS, Fedora Silverblue a MicroOS. Canonical připravuje desktopovou variantu Ubuntu Core vedle dosavadní serverové/embedded.

    Fluttershy, yay! | Komentářů: 0
    1.6. 13:33 | Upozornění

    Z aktualizovaného seznamu chyb (pdf) procesoru AMD EPYC 7002: #1474 - procesor se po 1044 dnech od posledního resetu zasekne [reddit].

    Ladislav Hagara | Komentářů: 23
    1.6. 13:00 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.22. 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
    Twitter (nejen pro příležitostné čtení)
     (85%)
     (3%)
     (12%)
    Celkem 60 hlasů
     Komentářů: 3, poslední dnes 19:07
    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: 1059×
    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.