Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.6. Přehled novinek s náhledy v oznámení na blogu.
V Edici CZ.NIC, knižní řady správce české národní domény, vychází nová kniha Martina Malého Kódy, buildy, firmwary. Autor po půl roce od vydání předchozího titulu přichází se svou již sedmou knihou, tentokrát zaměřenou na vývoj programového vybavení pro embedded zařízení. Publikace s podtitulem Základy vývojářského řemesla pro tvůrce hobby elektroniky nabízí praktického průvodce pro všechny, kdo své projekty vytvořené s Arduinem
… více »V Brně na FIT VUT probíhá dvoudenní open source komunitní konference DevConf.CZ 2026. Na programu je celá řada zajímavých přednášek, lightning talků, meetupů a workshopů. Přednášky lze sledovat i online na YouTube kanálu konference. Aktuální dění lze sledovat na Matrixu, 𝕏 nebo Mastodonu.
Byla vydána nová verze 15.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.
Vývojáři Ubuntu představili projekt Myna, tj. iniciativu zaměřenou na přidání funkce převodu řeči na text do prostředí desktopu Ubuntu. Dle plánu již v Ubuntu 26.10.
Společnost Epic Games představila nový open source systém pro správu verzí Lore navržený pro "bezprecedentní škálovatelnost dat i týmů a optimalizovaný pro projekty, včetně her a zábavy, které kombinují kód s velkými binárními soubory, aby uspokojil potřeby vývojářů i umělců". Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Úřad pro ochranu hospodářské soutěže (ÚOHS) provedl v říjnu 2024 místní šetření u společnosti Seznam.cz. Úřad prověřoval důvodné podezření na možné protisoutěžní jednání, konkrétně zneužití dominantního postavení. Krajský soud v Brně v květnu 2025 konstatoval, že toto šetření bylo nezákonné. Nejvyšší správní soud (NSS) včera rozhodl, že šetření bylo provedeno v souladu se zákonem. Krajský soud bude muset případ posoudit znovu.
Byl představen skládací telefon Commodore Callback 8020. Ani hloupý, ani chytrý. Pro fanoušky Commodore a digitálního minimalismu. Bez webového prohlížeče a sociálních sítí. S předinstalovaným WhatsAppem. S operačním systémem Sailfish OS.
V OpenBSD byla objevena 27 let stará chyba v ppp pomocí níž lze vzdáleně obejít autentifikaci. Chyba byla nahlášena 12.6. a 14.6. byla opravena. Bližší info v článku A 27-Year-Old Authentication Bypass in OpenBSD's PPP Stack.
Odpověď Evropské komise (pdf) k evropské občanské iniciativě Stop Destroying Videogames, jež je součástí hnutí Stop Killing Games: "Komise se domnívá, že v této fázi nemůže navrhnout právní povinnost zachovat hratelnost videoher poté, co přestaly být poskytovány komerčně. Důvodem jsou i stávající práva duševního vlastnictví. Podle autorského práva EU mají nositelé práv výlučná práva ke svým výtvorům. Kromě autorských práv mohou být
… více »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','')
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)
Řešení dotazu:
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.
.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.)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;).
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í.
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.
create table pruchod(jmeno varchar(255), created TIMESTAMP DEFAULT NOW());Po updatu sloupce
jmeno se created nezmění.
Š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í.
default při create table):NOW() a při každém UPDATE nastavení na NOW()`name_changedat` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP`name_changedat` TIMESTAMP;NOW()`name_createdat` TIMESTAMP DEFAULT CURRENT_TIMESTAMPUPDATE na NOW() (ale funkční to bude jen tehdy je-li povoleno NO_ZERO_DATE)`name_createdat` 0 ON UPDATE CURRENT_TIMESTAMPinsert, tak i u update lze hodnotu explicitně přepsat.
NOW() funguje.
Tiskni
Sdílej: