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

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.8.

    Ladislav Hagara | Komentářů: 0
    dnes 14:22 | IT novinky

    Herní studio Hangar 13 vydalo novou Mafii. Mafia: Domovina je zasazena do krutého sicilského podsvětí na začátku 20. století. Na ProtonDB je zatím bez záznamu.

    Ladislav Hagara | Komentářů: 0
    dnes 13:22 | IT novinky

    Operátor O2 má opět problémy. Jako omluvu za pondělní zhoršenou dostupnost služeb dal všem zákazníkům poukaz v hodnotě 300 Kč na nákup telefonu nebo příslušenství.

    Ladislav Hagara | Komentářů: 4
    dnes 05:55 | IT novinky

    Společnost OpenAI představila GPT-5 (YouTube).

    Ladislav Hagara | Komentářů: 0
    dnes 05:00 | Nová verze

    Byla vydána (𝕏) červencová aktualizace aneb nová verze 1.103 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.103 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

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

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 7
    včera 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

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

    Byla vydána verze 1.89.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.

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

    Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.

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

    Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (44%)
     (21%)
     (4%)
     (6%)
     (3%)
     (1%)
     (1%)
     (19%)
    Celkem 298 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Možno bug v MariaDB

    7.3.2017 20:09 Peter
    Možno bug v MariaDB
    Přečteno: 1107×
    Příloha:
    Dobrý deň vám prajem.

    Robím si aplikáciu na faktúry a narazil som na zaujímavú chybu v MariaDB. Na notebooku mám Fedora 25 a MariaDB 10.1.21 a insert jednej položky neprejde, respektíve prejde bez chyby, ale nič sa nevloží
    insert into invoice (id_contact) values ('1');
    Bolo vložených 0 riadkov. (Dopyt zabral 0.0005 sekúnd.)
    
    Čiže v podstate pre databázu je všetko v poriadku, len nevloží nič, ale zato takéto niečo funguje a aj vloží záznam:
    insert into invoice values (null,'1','0000-00-00','0000-00-00','0','0000-00-00','0','0','0','0000-00-00','0','0','0','','','');
    Bol vložený 1 riadok.
    Vložený riadok id: 1 (Dopyt zabral 0.0005 sekúnd.)
    
    Pravdepodobne je problém s cudzími kľúčmi, lebo na tabuľke bez nich funguje aj skrátený zápis. Na MySQL 5.7.17 všetko funguje ako má.

    Kompletná databáza je priložená v prílohe.

    Mám chybu niekde ja, alebo je to chyba v MariaDB?

    Za pomoc vám vopred veľmi pekne ďakujem.

    Odpovědi

    8.3.2017 12:43 Roman DAVID | skóre: 24 | Brno
    Rozbalit Rozbalit vše Re: Možno bug v MariaDB
    Zdravim, v tabulce invoice nastavte následujícím sloupcům výchozí hodnoty:
    `delivery_date` 
     `maturity_date`
    `invoice_date` 
    `prefix` 
    `suffix` 
    `comment`
    
    Pak to bude fungovat. Funkční struktura tabulky vypadá takto:
    CREATE TABLE `invoice` (
      `id` int(10) UNSIGNED NOT NULL,
      `id_contact` int(10) UNSIGNED NOT NULL,
      `delivery_date` date DEFAULT NULL,
      `maturity_date` date DEFAULT NULL,
      `invoice` tinyint(1) NOT NULL,
      `invoice_date` date DEFAULT NULL,
      `invoice_year` int(4) UNSIGNED NOT NULL,
      `invoice_number` int(6) UNSIGNED NOT NULL,
      `cancel` tinyint(1) NOT NULL,
      `cancel_date` date NOT NULL,
      `cancel_year` int(4) UNSIGNED NOT NULL,
      `cancel_number` int(6) UNSIGNED NOT NULL,
      `price` decimal(12,2) NOT NULL,
      `prefix` text,
      `suffix` text,
      `comment` text
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    Pokud máte pro typ 'date' nastaveno NOT NULL, tak DB neví co tam má dát, když mu neposkytnete validní datum
    v rámci SQL dotazu "insert into...". To stejné z nějakého důvodu platí i pro typ 'text'.
    8.3.2017 15:21 chrono
    Rozbalit Rozbalit vše Re: Možno bug v MariaDB
    Tie prázdne stĺpce sa riešia v TRIGGER `invoice:before_insert` (netuším, prečo nie je použitá DEFAULT hodnota priamo pri vytváraní tabuľky), takže to asi problém nebude.
    8.3.2017 16:42 Roman DAVID | skóre: 24 | Brno
    Rozbalit Rozbalit vše Re: Možno bug v MariaDB
    Protože žádnou DEFAULT nemáte nastavenou !

    Máte jen "NOT NULL" , ale chybí default.

    Právě na těch triggerech to pohoří.

    Mimochode, zkoušel jste to s mnou navrhovanou strukturou ?

    Mě to po těchto upravách funguje.

    A když už mi nevěříte, tak si po insertu následně dejte SHOW WARNINGS;

    Pokud vás ani to nepřesvědčí, tak už pak nevím.....
    8.3.2017 21:03 jekub
    Rozbalit Rozbalit vše Re: Možno bug v MariaDB
    a proc by to chrono zkousel, jeho problem to neni.
    8.3.2017 21:18 jekub
    Rozbalit Rozbalit vše Re: Možno bug v MariaDB
    Funkční struktura tabulky vypadá takto:

    ta puvodni je snad nefunkcni?

    Pokud máte pro typ 'date' nastaveno NOT NULL, tak DB neví co tam má dát

    kdyz nevi, tak null. Sloupec je not null, ergo chyba.
    10.3.2017 20:49 Ivan2 | skóre: 5
    Rozbalit Rozbalit vše Re: Možno bug v MariaDB
    <flame > Jeden by ocekaval, ze to napise neco jako "integrity violation error", nebo tak neco. Ale ono jen nic nevlozi. </flame >

    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.