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í
×
    13.9. 17:33 | Pozvánky

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.

    Ladislav Hagara | Komentářů: 0
    13.9. 01:33 | IT novinky

    Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si

    … více »
    Ladislav Hagara | Komentářů: 3
    12.9. 14:00 | Nová verze

    Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.

    Ladislav Hagara | Komentářů: 0
    12.9. 12:00 | Zajímavý článek

    Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).

    🇵🇸 | Komentářů: 20
    12.9. 05:33 | Bezpečnostní upozornění

    Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.

    Ladislav Hagara | Komentářů: 0
    11.9. 22:00 | Komunita

    V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.

    Ladislav Hagara | Komentářů: 16
    11.9. 17:33 | Nová verze

    Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 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.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 1
    11.9. 15:33 | IT novinky

    Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.

    Ladislav Hagara | Komentářů: 0
    11.9. 15:00 | IT novinky

    Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.

    Ladislav Hagara | Komentářů: 7
    10.9. 21:22 | Nová verze

    Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (81%)
     (7%)
     (3%)
     (3%)
     (4%)
     (2%)
    Celkem 176 hlasů
     Komentářů: 12, poslední 10.9. 13:00
    Rozcestník

    Dotaz: Mysql problem s cizim klicem

    1.3.2012 13:46 Stoupa
    Mysql problem s cizim klicem
    Přečteno: 909×
    Zdravim, mam tabulky v databazi
    CREATE TABLE `komentare` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `id_ukolu` int(11) DEFAULT NULL,
      `id_projektu` int(11) DEFAULT NULL,
      `id_uzivatele` int(11) NOT NULL,
      `popis` text COLLATE utf8mb4_czech_ci NOT NULL,
      `datum` datetime NOT NULL,
      `zmena` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
      PRIMARY KEY (`id`),
      KEY `id_ukolu` (`id_ukolu`),
      KEY `id_uzivatele` (`id_uzivatele`),
      KEY `id_projektu` (`id_projektu`),
      CONSTRAINT `komentare_ibfk_4` FOREIGN KEY (`id_projektu`) REFERENCES `projekty` (`id`),
      CONSTRAINT `komentare_ibfk_1` FOREIGN KEY (`id_uzivatele`) REFERENCES `uzivatele` (`uid`) ON DELETE CASCADE,
      CONSTRAINT `komentare_ibfk_2` FOREIGN KEY (`id_ukolu`) REFERENCES `ukoly` (`id`) ON DELETE CASCADE
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_czech_ci;
    
    CREATE TABLE `projekty` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `vedouci` int(11) NOT NULL,
      `nazev` varchar(30) COLLATE utf8mb4_czech_ci NOT NULL,
      `popis` text COLLATE utf8mb4_czech_ci NOT NULL,
      `zacatek` date NOT NULL,
      `konec` date NOT NULL,
      `hotovo` tinyint(1) NOT NULL DEFAULT '0',
      PRIMARY KEY (`id`),
      KEY `vedouci` (`vedouci`),
      CONSTRAINT `projekty_ibfk_2` FOREIGN KEY (`vedouci`) REFERENCES `uzivatele` (`uid`) ON DELETE CASCADE
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_czech_ci;
    
    CREATE TABLE `ukoly` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `id_projektu` int(11) NOT NULL,
      `nazev` varchar(30) COLLATE utf8mb4_czech_ci NOT NULL,
      `popis` text COLLATE utf8mb4_czech_ci NOT NULL,
      `zacatek` date NOT NULL,
      `konec` date NOT NULL,
      `hotovo` tinyint(1) NOT NULL DEFAULT '0',
      `id_predka` int(11) NOT NULL DEFAULT '0',
      PRIMARY KEY (`id`),
      KEY `id_projektu` (`id_projektu`),
      CONSTRAINT `ukoly_ibfk_1` FOREIGN KEY (`id_projektu`) REFERENCES `projekty` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_czech_ci;
      
    Kde tabulka komentare ma dva cizi klice id_projektu a id_ukolu. Ovsem pri pridavani komentare do databaze prikazem

    insert into komentare values('','','','1','asfas','2012-02-28 07:28:00','')

    dostavam chybu

    Chyba v dotazu: Cannot add or update a child row: a foreign key constraint fails (`bakp_db`.`komentare`, CONSTRAINT `komentare_ibfk_2` FOREIGN KEY (`id_ukolu`) REFERENCES `ukoly` (`id`) ON DELETE CASCADE)

    Nevite nekdo kde by mohl byt problem? Co jsem procital internet tak jsem narazil na vyroky, ze cizi klic muze byt nabyvat hodnoty null.

    Řešení dotazu:


    Odpovědi

    1.3.2012 14:19 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Vy tam nevkládáte NULL, ale prázdný řetězec. MySQL to kupodivu povolí a asi jej převede na nějaké číslo. Předpokládám, že jste chtěl spíš provést
    INSERT INTO komentare (id, id_ukolu, id_projektu, id_uzivatele, popis, datum, zmena)
      VALUES (DEFAULT, NULL, NULL, 1, 'asfas', '2012-02-28 07:28:00', DEFAULT)
    
    nebo
    INSERT INTO komentare (id_uzivatele, popis, datum)
      VALUES (NULL, NULL, 1, 'asfas', '2012-02-28 07:28:00')
    
    když už tam máte nadefinované ty výchozí hodnoty.

    Jinak nechápu, proč se tam všude snažíte nacpat řetězce, když to mají být čísla. Výchozí hodnota pro sloupec zmena taky vypadá dost podivně a s velkou pravděpodobností by tam spíš mělo být NULL.
    1.3.2012 15:39 Stoupa
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Dekuji moc mi to pomohlo.
    2.3.2012 09:23 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Doplnění ke konverzi:
    Implicitní konverze textu na číslo zařídí, že nečíselný řetězec (respektive neobsahující zleva nějakou číselnou reprezentaci) je nula - tedy i prázdný řetězec.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.3.2012 09:48 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Abych předešel další debatě o implicitní konverzi :-).
    Je to dle nastavení serveru, případně dle nastaveni uživatelského(session) sql_mode, pokud je nastavení takové, jak bylo vždy u MySql zvykem,tedy ne-striktní--volné, tak je při konverzi na číslo z hodnot '' nebo 'kuk' nebo '1kuk' vyvolán jen warning (v prvních dvou případech 1366, tedy nekorektní hodnota, v posledním případě 1265, tedy ořezání dat.)
    Pokud je nastaven rozumnější režim (například pomocí: set @@session.sql_mode='STRICT_ALL_TABLES';), tak jsou všechna tato varování již chybami (stávající nastavení lze zjisti přes select @@sql_mode;).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    1.3.2012 17:14 Kit
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Častou chybou je chybná práce s timestampem. Chybně:
    insert into komentare values('','','','1','asfas','2012-02-28 07:28:00','');
    lépe:
    insert into komentare values('','','','1','asfas',now(),'');
    Nejlépe asi funguje datový typ timestamp, který se aktualizuje při každé změně záznamu. Ovšem i to je potřeba si řádně rozmyslet, protože vždy to vhodné není.

    Je možné, že podobná programátorská chyba způsobila včerejší nefunkčnost systému na vydávání občanských průkazů. SQL databáze takové chyby už dlouho nedělají.
    2.3.2012 08:19 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Pak by se hodilo mít now() jako default pro daný sloupec, případně ho rovnou plnit nějakým triggerem a zakázat jeho změnu. Ale nevím, co z toho je řešitelné v MySQL.
    2.3.2012 08:58 Kit
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Tohle funguje:
    create table pruchod(jmeno varchar(255), created TIMESTAMP DEFAULT NOW());
    Po updatu sloupce jmeno se created nezmění.
    2.3.2012 09:10 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Jistě, nemyslel jsem si, že je na tom MySQL zas tak špatně :-) Šlo mi spíš o to, aby tu hodnotu nebylo možné při insertu nastavit na jinou nebo updatem změnit. Ale na takhle silné kontroly na straně databáze si uživatelé MySQL zpravidla nehrají.
    2.3.2012 09:31 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Definice sloupce v MySQL (bo nelze použít fce v default při create table):

    Iniciliazicae na NOW() a při každém UPDATE nastavení na NOW()
    `name_changedat` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
    nebo
    `name_changedat` TIMESTAMP;

    Jen iniciliazicae na NOW()
    `name_createdat` TIMESTAMP DEFAULT CURRENT_TIMESTAMP

    Jen UPDATE na NOW() (ale funkční to bude jen tehdy je-li povoleno NO_ZERO_DATE)
    `name_createdat` 0 ON UPDATE CURRENT_TIMESTAMP

    (samozřejmě platí, že nějaký sloupec musí být změněn, tj. musí dojít ke změně nějaké hodnoty řádku)

    Ovšem jak při insert, tak i u update lze hodnotu explicitně přepsat.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.3.2012 09:57 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Aha, beru zpět na základě příspěvku a odzkoušení, že nelze použít funkce, evidentně alespoň NOW() funguje.
    Ale pomoci update lze hodnotu přepsat, aby to nebylo možné, musel by se použít trigger.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.3.2012 09:47 Kit
    Rozbalit Rozbalit vše Re: Mysql problem s cizim klicem
    Dá se využít GRANT a pohledy, ale na to si uživatelé MySQL zpravidla nehrají.

    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.