Joe Brockmeier z Linux Weekly News vyzkoušel různé forky webového prohlížeče Mozilla Firefox: především GNU IceCat, Floorp, LibreWolf a Zen. V článku shrnuje, v čem se liší od výchozí konfigurace Firefoxu, co mají za vlastní funkcionalitu, jak a kým jsou udržované atd.
Byl vydán Debian 12.10, tj. desátá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
Byla vydána nová verze 4.5 svobodného notačního programu MuseScore (Wikipedie). Představení novinek v oznámení v diskusním fóru a také na YouTube.
Byla vydána nová verze 8.6.0 správce sbírky fotografií digiKam (Wikipedie). Přehled novinek i s náhledy v oficiálním oznámení (NEWS). Nejnovější digiKam je ke stažení také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.
O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2025. Na programu je celá řada zajímavých přednášek a workshopů. Vstup je zdarma. Přednášky lze sledovat i online na YouTube.
Byla vydána nová verze 2.49.0 distribuovaného systému správy verzí Git. Přispělo 89 vývojářů, z toho 24 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Premiér Petr Fiala (ODS) dnes na síti X vyloučil, že by za jeho vlády mohla začít platit vyhláška, podle níž by poskytovatelé internetového připojení měli uchovávat adresy internetových stránek, na které se lidé připojují.
Flock 2025, tj. konference pro přispěvatele a příznivce Fedory, proběhne od 5. do 8. června v Praze.
Zemřel Mark Klein, který dlouhá léta pracoval pro telekomunikační firmu AT&T a proslavil se jako whistleblower, když zveřejnil informace o spolupráci AT&T s agenturou NSA. Cílem spolupráce bylo sledovat veškerou komunikaci občanů za pomocí zařízeních v místnosti 641A. O spolupráci obou subjektů napsal knihu Wiring Up The Big Brother Machine...And Fighting It.
Byla vydána nová verze 16 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.
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í.
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_TIMESTAMP
UPDATE
na NOW()
(ale funkční to bude jen tehdy je-li povoleno NO_ZERO_DATE)`name_createdat` 0 ON UPDATE CURRENT_TIMESTAMP
insert
, tak i u update
lze hodnotu explicitně přepsat.
NOW()
funguje.
Tiskni
Sdílej: