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 03:33 | IT novinky

    Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.

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

    Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    včera 16:33 | IT novinky

    Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.

    Ladislav Hagara | Komentářů: 1
    včera 15:55 | Nová verze

    Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Nová verze

    Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.10. 23:55 | Komunita

    Ubuntu 26.04 LTS bude (𝕏) Resolute Raccoon (rezolutní mýval).

    Ladislav Hagara | Komentářů: 3
    6.10. 21:00 | Nová verze

    Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    6.10. 20:11 | Komunita

    Linuxová distribuce Frugalware (Wikipedie) ke konci roku 2025 oficiálně končí.

    Ladislav Hagara | Komentářů: 0
    6.10. 17:22 | Nová verze

    Byla vydána nová verze 3.0.6 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP bude brzy k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    6.10. 16:11 | IT novinky

    Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.

    Ladislav Hagara | Komentářů: 1
    Jaké řešení používáte k vývoji / práci?
     (39%)
     (46%)
     (15%)
     (17%)
     (21%)
     (15%)
     (18%)
     (16%)
     (16%)
    Celkem 192 hlasů
     Komentářů: 13, poslední dnes 07:41
    Rozcestník

    Dotaz: MySQL a foreign keys

    svido avatar 16.3.2014 10:37 svido | skóre: 28
    MySQL a foreign keys
    Přečteno: 872×
    Ahoj, bohužel už několik jsem nenavrhoval DB, takže jsem dost zapomněl, ale i tak by definice cizích klíčů měla být v pořádku. Ale není, pokud chci vymazat tabulku `User`, tak dostanu hlášku: "#1701 - Cannot truncate a table referenced in a foreign key constraint (`golf_portal`.`User2Newsletter`, CONSTRAINT `fk_User2Newsletter_User1` FOREIGN KEY (`UserID`) REFERENCES `golf_portal`.`User` (`id`))"

    Děkuji za kažou radu, já to fakt nevidím... :-(
    CREATE TABLE `User` (
      `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
      `AccountStateID` tinyint(3) unsigned NOT NULL,
      `Email` varchar(128) NOT NULL,
      `CityID` int(10) unsigned DEFAULT NULL,
      `Name` varchar(64) NOT NULL,
      `Surname` varchar(64) NOT NULL,
      `Password` char(40) NOT NULL,
      `IsActive` tinyint(1) NOT NULL DEFAULT '0',
      `Phone` varchar(32) DEFAULT NULL,
      `LinkedInUrl` varchar(128) DEFAULT NULL,
      `CgfID` int(10) unsigned DEFAULT NULL,
      `HCP` smallint(5) unsigned DEFAULT NULL,
      `Salt` char(40) DEFAULT NULL,
      `ActivationCode` char(40) DEFAULT NULL,
      `Created` int(10) unsigned NOT NULL,
      `Modified` int(10) unsigned DEFAULT NULL,
      PRIMARY KEY (`id`),
      UNIQUE KEY `unq_Email` (`Email`),
      UNIQUE KEY `unq_CgfID` (`CgfID`),
      KEY `fk_User_CodeCity1_idx` (`CityID`),
      KEY `fk_User_UserAccountState1_idx` (`AccountStateID`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    
    CREATE TABLE `User2Newsletter` (
      `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
      `UserID` int(10) unsigned NOT NULL,
      `IsActive` tinyint(1) NOT NULL DEFAULT '0',
      PRIMARY KEY (`id`),
      UNIQUE KEY `unq_UserID` (`UserID`),
      KEY `fk_User2Newsletter_User1_idx` (`UserID`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    --
    -- Constraints for dumped tables
    --
    
    ALTER TABLE `User`
      ADD CONSTRAINT `fk_User_CodeCity1` FOREIGN KEY (`CityID`) REFERENCES `CodeCity` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
      ADD CONSTRAINT `fk_User_CodeUserAccountState1` FOREIGN KEY (`AccountStateID`) REFERENCES `CodeUserAccountState` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;
    
    ALTER TABLE `User2Newsletter`
      ADD CONSTRAINT `fk_User2Newsletter_User1` FOREIGN KEY (`UserID`) REFERENCES `User` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;

    Odpovědi

    16.3.2014 11:41 jekub
    Rozbalit Rozbalit vše Re: MySQL a foreign keys
    #1701 - Cannot truncate

    Nemůžete použít truncate na tabulku User, pokud User2Newsletter obsahuje data.

    Použijte delete, nebo nejprve truncate User2Newsletter.
    svido avatar 16.3.2014 12:32 svido | skóre: 28
    Rozbalit Rozbalit vše Re: MySQL a foreign keys
    Já měl za to, že to dříve fungovalo. Truncate je v podstatě jako delete - jsem myslel a předpokládal jsem, že si constrainty poradi. Přijde mi to dost divný, když budu mít třeba 50 tabulek s cizimi klici z jedné tabulky, tak mi přijde nelogické dávat truncate na tabulkach co maji cizi klic nebo mazat jednotlive
    16.3.2014 13:03 jekub
    Rozbalit Rozbalit vše Re: MySQL a foreign keys
    truncate - DDL, delete - DML
    17.3.2014 09:45 axel
    Rozbalit Rozbalit vše Re: MySQL a foreign keys
    Jestli to drive fungovalo nevim, ale truncate rozhodne neni "jako delete", na to si dej pozor.
    17.3.2014 11:42 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: MySQL a foreign keys

    TRUNCATEje operace „údržbová“ nebo-li pracující ze strukturou, ne s daty (i když je zlikviduje) dala by se popsat jako DROP TABLE a CREATE TABLE.

    DELETE FROM table bez WHERE clausule smaže všechny data, a neřekl bych, že jednotlivě, pro každý záznam se provede to co má, ale jsou smazány všechny (ale k uvolnění místa na disku pravděpodobně nedojde, lze následně použít optimize table, nebo zmíněné truncate jako údržbu DB).

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    22.3.2014 10:25 Filip Jirsák
    Rozbalit Rozbalit vše Re: MySQL a foreign keys
    Delete při mazání provádí všechny kontroly, např. abyste nesmazal řádek, na který odkazuje cizí klíč z jiné tabulky. Truncate se jednotlivými řádky nezabývá, smaže všechna data z tabulky. Takže musí mít jistotu, že jsou všechny kontroly splněné - tedy například že se tím vyprázdnění tabulky nesmaže záznam, na který by odkazoval cizí klíč z jiné tabulky.

    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.