Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
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: 7249
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: 7249
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


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Steam è ora in grado di dirti se ...
Intel resuscita Comet Lake: arriva il 'n...
Xiaomi 15 Ultra con lenti Leica e HyperA...
La gamma del Kobo Clara Colour si aggior...
Microsoft e OpenAI, accordo preliminare ...
Due Smart TV LG in offerta su Amazon: OL...
Due scope elettriche super accessoriate ...
Intel perde un altro pezzo da novanta: a...
Scende al prezzo impossibile di 149€ il ...
SK hynix svela la mostruosa HBM4, la mem...
ECOVACS non si ferma più e conqui...
Da non credere: crolla a 899€ MacBook Ai...
ASUS ROG porta in Italia una nuova tasti...
Samsung Galaxy S26 Ultra: brutte notizie...
Cos'è RSL, il nuovo standard che ...
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: 08:49.


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