Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Abbiamo provato per molti giorni il nuovo Z Fold7 di Samsung, un prodotto davvero interessante e costruito nei minimi dettagli. Rispetto al predecessore, cambiano parecchie cose, facendo un salto generazionale importante. Sarà lui il pieghevole di riferimento? Ecco la nostra recensione completa.
The Edge of Fate è Destiny 2.5. E questo è un problema
The Edge of Fate è Destiny 2.5. E questo è un problema
Bungie riesce a costruire una delle campagne più coinvolgenti della serie e introduce cambiamenti profondi al sistema di gioco, tra nuove stat e tier dell’equipaggiamento. Ma con risorse limitate e scelte discutibili, il vero salto evolutivo resta solo un’occasione mancata
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
AMD ha aggiornato l'offerta di CPU HEDT con i Ryzen Threadripper 9000 basati su architettura Zen 5. In questo articolo vediamo come si comportano i modelli con 64 e 32 core 9980X e 9970X. Venduti allo stesso prezzo dei predecessori e compatibili con il medesimo socket, le nuove proposte si candidano a essere ottimi compagni per chi è in cerca di potenza dei calcolo e tante linee PCI Express per workstation grafiche e destinate all'AI.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-09-2008, 22:39   #1
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
[MySQL] vincoli ON DELETE XXX e ON UPDATE XXX

sto usando seriamente MySQL per la prima volta, e mi trovo di fronte alla seguente difficoltà. mettiamo che io eseguo le seguenti istruzioni:
Codice:
CREATE DATABASE test;
USE test;

CREATE TABLE parent
(
    lol BOOLEAN NOT NULL PRIMARY KEY  /* nome e tipo scelti a caso, tanto per avere una chiave primaria */
);

CREATE TABLE child
(
    asd BOOLEAN NOT NULL REFERENCES parent(lol) ON DELETE CASCADE ON UPDATE CASCADE
);
non dovrei aver fatto grosse castronerie, no? quello che io vorrei ottenere è che se io cancello una entry dalla tabella parent (una delle due possibili, visto che il campo è booleano ) lui automaticamente mi cancelli la corrispondente entry (se esiste) nella tabella child, ma questo non succede.

se faccio questo:
Codice:
DELETE FROM parent WHERE lol="true";
la entry in child rimane. c'è qualcosa che non sto capendo...

Ultima modifica di 71104 : 03-09-2008 alle 22:42.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2008, 22:45   #2
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
altra cosa: la clausola REFERENCES non dovrebbe fare in modo che mi venga vietato di inserire una entry in child se per quel campo non esiste un valore corrispondente in parent?

praticamente facendo questo:
Codice:
INSERT INTO child VALUES(TRUE);
la entry viene inserita anche se parent è vuota.

c'è decisamente qualcosa che non sto capendo...

'sti vincoli non funzionano come mi pare di aver capito che debbano funzionare: le entries sembrano completamente scorrelate.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 07:25   #3
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Ti sei appena scontrato con una delle cazzate più grosse di MySQL: l'integrità referenziale ce l'hai (nel senso che funziona; il parsing viene effettuato per qualunque engine, per cui in questo momento tu stai vivendo nell'illusione di aver creato una struttura coerente e che sulla carta dovrebbe funzionare; solo sulla carta però: MySQL mica t'informa che poi, di fatto, non funzionerà ) soltanto con alcuni engine.

Nel tuo caso, non avendolo specificato, di default viene usato MyISAM, che ovviamente NON la supporta.

Io uso InnoDB come engine per farla funzionare. Modifica le tabelle in questo modo:
Codice:
CREATE TABLE parent
(
    lol BOOLEAN NOT NULL PRIMARY KEY  /* nome e tipo scelti a caso, tanto per avere una chiave primaria */
) engine=InnoDB;

CREATE TABLE child
(
    asd BOOLEAN NOT NULL REFERENCES parent(lol) ON DELETE CASCADE ON UPDATE CASCADE
) engine=InnoDB;
Vedrai che adesso ti funzionerà.

MySQL meriterebbe una pagina ad hoc su YourLanguageSucks.

Se poi vuoi usare un engine SQL degno di questo nome, puoi sempre provare FireBird.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 10:02   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Che io sappia le tabelle su MySQL, a meno che non sia una versione vecchia, vengono create come InnoDB.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 10:10   #5
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
l'avevo letta infatti questa storia di InnoDB sulla documentazione, ma mi pareva che valesse solo per l'istruzione FOREIGN KEY. comunque ho provato or ora con "engine=InnoDB" e non cambia nulla: "INSERT INTO" inserisce in child anche se il valore non è presente in parent, e "DELETE FROM parent" di cancellare a cascata non ci pensa neanche.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 11:08   #6
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Fosse Oracle ti potrei aiutare un pò di più. Con MySQL l'unica cosa che posso fare è dirti di dare un'occhiata qui:

http://dev.mysql.com/doc/refman/5.0/...nstraints.html

...e di usare InnoDB, che è l'unico motore che si avvicina ad un database relazionale.

Però per favore, non usare un boolean come PK. Nemmeno per prova. Ogni volta che qualcuno usa un boolean come PK, Gesù Bambino piange, lo sai vero?
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 11:19   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da shinya Guarda i messaggi
Fosse Oracle ti potrei aiutare un pò di più. Con MySQL l'unica cosa che posso fare è dirti di dare un'occhiata qui:

http://dev.mysql.com/doc/refman/5.0/...nstraints.html
mah, sentite a me pare scandaloso: ho provato a rifare il test utilizzando il codice di esempio che c'è nella pagina:
Codice:
CREATE TABLE parent (id INT NOT NULL,
                     PRIMARY KEY (id)
) ENGINE=INNODB;
CREATE TABLE child (id INT, parent_id INT,
                    INDEX par_ind (parent_id),
                    FOREIGN KEY (parent_id) REFERENCES parent(id)
                      ON DELETE CASCADE
) ENGINE=INNODB;
e con l'istruzione FOREIGN KEY effettivamente funziona... con REFERENCES messo direttamente accanto al campo invece no!! cioè, possibile che abbiano lasciato nel linguaggio un' "appendice" non funzionante? mi pare una cosa veramente oscena...
credo di non aver capito io qualcosa, ma mi piacerebbe tanto capirla sta cosa.


Quote:
Però per favore, non usare un boolean come PK. Nemmeno per prova. Ogni volta che qualcuno usa un boolean come PK, Gesù Bambino piange, lo sai vero?
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 11:41   #8
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
Secondo me fai prima ad usare un db più serio:

http://www.postgresql.org/

__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 11:46   #9
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
non sono io che decido quale database usare; io devo solo scrivere un programma Java che lo usa (si tratta della mia tesi ). esiste la possibilità che prossimamente migriamo a postgres, ma per ora mi piacerebbe molto se le cose funzionassero con MySQL
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 12:20   #10
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7240
qui c'è scritto che così come hai fatto te non ha alcun effetto e serve solo come promemoria
http://dev.mysql.com/doc/refman/6.0/...eign-keys.html
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 12:27   #11
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ammazza che schifo


grazie k0nt3


PS: altro che YourLanguageSucks...
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 12:28   #12
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7240
guarda per l'integrità referenziale non c'è paragone con postgreSQL
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 13:18   #13
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da cionci Guarda i messaggi
Che io sappia le tabelle su MySQL, a meno che non sia una versione vecchia, vengono create come InnoDB.
Vero. Ho fatto la prova con la 5.0 e crea tabelle InnoDB. Con la 4.x che io ricordi le creava con MyISAM.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy Z Fold7: un grande salto generazionale Recensione Samsung Galaxy Z Fold7: un grande sal...
The Edge of Fate è Destiny 2.5. E questo è un problema The Edge of Fate è Destiny 2.5. E questo ...
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello Ryzen Threadripper 9980X e 9970X alla prova: AMD...
Acer TravelMate P4 14: tanta sostanza per l'utente aziendale Acer TravelMate P4 14: tanta sostanza per l'uten...
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque Hisense M2 Pro: dove lo metti, sta. Mini proiett...
Fallito il primo lancio del razzo spazia...
Addio Bitcoin: in Algeria anche il solo ...
Amazon si inventa gli sconti al check-ou...
NVIDIA H20 torna in Cina? Non è d...
Addio fatica col tagliaerba: i robot sma...
Arm: ricavi di nuovo oltre il miliardo d...
Viaggi a 200 km/h sotto Nashville? Ecco ...
Gran ritorno con doppio sconto: 25,99€ p...
Huawei punta sull'accumulo energetico gr...
HyperOS 3 di Xiaomi: arriva con Android ...
Amazfit sempre più scontati: scen...
Norme e IA migliorano la postura di sicu...
Robot aspirapolvere Narwal ai minimi sto...
Incentivi per l'acquisto di auto elettri...
Radeon, stuttering con il ray tracing ne...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 14:08.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v