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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 1
dnes 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 0
včera 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 5
včera 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 33
včera 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 9
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 25
2.12. 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 18
2.12. 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 6
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 774 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Mysql problem s cizim klicem

1.3.2012 13:46 Stoupa
Mysql problem s cizim klicem
Přečteno: 799×
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: 66 | 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: 66 | 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: 66 | 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.