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

    Byla vydána nová stabilní verze 25.05 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Warbler. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.

    Ladislav Hagara | Komentářů: 0
    včera 18:11 | Nová verze

    Multiplatformní open source spouštěč her Heroic Games Launcher byl vydán v nové stabilní verzi 2.17.0 Franky (Mastodon, 𝕏). Přehled novinek na GitHubu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 18:00 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 26 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 14:55 | IT novinky

    Klávesnice IBM Enhanced Keyboard, známá také jako Model M, byla poprvé představena v roce 1985, tzn. před 40 lety, s počítači IBM 7531/7532 Industrial Computer a 3161/3163 ASCII Display Station. Výročí připomíná článek na zevrubném sběratelském webu Admiral Shark's Keyboards. Rozložení kláves IBM Enhanced Keyboard se stalo průmyslovým standardem.

    Fluttershy, yay! | Komentářů: 4
    včera 12:00 | Nová verze

    Vyšlo Pharo 13 s vylepšenou podporou HiDPI či objektovým Transcriptem. Pharo je programovací jazyk a vývojové prostředí s řadou pokročilých vlastností.

    Pavel Křivánek | Komentářů: 1
    včera 04:00 | IT novinky

    Java má dnes 30. narozeniny. Veřejnosti byla představena 23. května 1995.

    Ladislav Hagara | Komentářů: 6
    22.5. 21:55 | IT novinky

    1. července Mozilla vypne službu Fakespot pro detekci podvodných recenzí v internetových obchodech. Mozilla koupila Fakespot v květnu 2023.

    Ladislav Hagara | Komentářů: 1
    22.5. 21:33 | IT novinky

    8. července Mozilla vypne službu Pocket (Wikipedie) pro ukládání článků z webu na později. Do 8. října si uživatelé mohou vyexportovat data. Mozilla koupila Pocket v únoru 2017. Několik měsíců byl Pocket integrovanou součástí Firefoxu.

    Ladislav Hagara | Komentářů: 5
    22.5. 13:22 | Upozornění

    Turris OS má aktuálně problém s aktualizací související s ukončením podpory protokolu OCSP u certifikační autority Let's Encrypt.

    Ladislav Hagara | Komentářů: 4
    22.5. 04:00 | Zajímavý článek

    Nevidomý uživatel Linuxu v blogu upozornil na tristní stav přístupnosti na linuxovém desktopu (část první, druhá, závěr), přičemž stížnosti jsou podobné jako v roce 2022. Vyvolal bouřlivou odezvu. Následně např. Georges Stavracas shrnul situaci v GNOME. Debata o jiném aspektu přístupnosti, emulaci vstupu pod Waylandem, také proběhla na Redditu.

    Fluttershy, yay! | Komentářů: 8
    Jaký je váš oblíbený skriptovací jazyk?
     (57%)
     (28%)
     (7%)
     (3%)
     (0%)
     (0%)
     (6%)
    Celkem 90 hlasů
     Komentářů: 6, poslední 22.5. 14:43
    Rozcestník

    Dotaz: MySQL 4.0.25 & problém s definicí cizího klíče

    17.1.2006 19:19 dau | blog: dau | Brno
    MySQL 4.0.25 & problém s definicí cizího klíče
    Přečteno: 800×

    Zdravím

    Snažím se s pomocí RoR naprogramovat jistou aplikaci a vše bylo OK, dokud jsem si nezačal hrát s Migrations. Tedy ono to funguje, ale něco "shnilého" se děje s MySQL. Tedy zdá se. Potýkám se s tím už třetí den bez jakéhokoliv výsledku, proto se obracím sem v naději, že někdo pozná v čem je problém, či kde dělám chybu.

    Situace je jednoduchá. Mám několik tabulek a teď potřebuji přidat další - s cizím klíčem ukazujícím do již existující tabulky. Příkaz create používám ve stejné syntaxi jako dříve, ovšem s výsledkem:

    Mysql::Error: Can't create table './oncosys_dev/#sql-a96_ab.frm' (errno: 150): ALTER TABLE plans ADD CONSTRAINT fk_plans_treatment FOREIGN KEY ( treatment_id ) REFERENCES treatments( id )
    
    Zde je částečná "struktura" tabulek, které s problémem souvisí:
    CREATE TABLE plans (
      id int(11) NOT NULL auto_increment,
      treatment_id int(10) default '0',
      name varchar(255) default NULL,
      PRIMARY KEY  (id),
      KEY treatment_id (treatment_id)
    ) TYPE=InnoDB;
    
    -- --------------------------------------------------------
    
    CREATE TABLE treatments (
      id int(10) unsigned NOT NULL auto_increment,
      patient_id int(10) unsigned default '0',
      machine_id tinyint(3) unsigned default '0',
      plan varchar(6) default NULL,
      description varchar(200) default NULL,
      PRIMARY KEY  (id),
      KEY plan (plan),
      KEY machine_id (machine_id),
      KEY patient_id (patient_id)
    ) TYPE=InnoDB COMMENT='Basic table with treatments';
    
    -- 
    -- Omezení pro tabulku `treatments`
    -- 
    ALTER TABLE `treatments`
      ADD CONSTRAINT `fk_treatments_machine` FOREIGN KEY (`machine_id`) REFERENCES `machines` (`id`),
      ADD CONSTRAINT `fk_treatments_patient` FOREIGN KEY (`patient_id`) REFERENCES `patients` (`id`);
    

    Právě v tabulce plans by měla být uvedena definice cizího klíče

    ALTER TABLE plans ADD CONSTRAINT fk_plans_treatment FOREIGN KEY ( treatment_id ) REFERENCES treatments( id )

    Pokud ji tam dodám přímo, skončí vše s již výše zapsanou chybou, pokud definici FOREIGN KEY odstraním, tabulka se bez problému vytvoří. Zkoušel jsem i vytvořit tabulku a cizí klíč vytvořit následně, výsledek tentýž. V phpMyAdmin to zabrečelo něco jako že není index na treatment_id - čemuž se mi nechce věřit, když to vypisuje, že tam je...

    Najde se někdo, kdo by dokázal poradit? Předem díky. Jinak vše provozuji na Gentoo Linuxu, verze MySQL 4.0.25.

    Není nic tak legračního, jako nechat ze sebe dělat totálního blbce.

    Na otázku zatím nikdo bohužel neodpověděl.

    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.