Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-09-2008, 23: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 23:42.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2008, 23: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, 08: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, 11: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, 11: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, 12: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, 12: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, 12: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, 12: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, 13:20   #10
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
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, 13: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, 13:28   #12
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
guarda per l'integrità referenziale non c'è paragone con postgreSQL
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2008, 14: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


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Samsung TV in offerta su Amazon: Neo QLE...
Sì, c'è un display è...
Fast restart di Windows spiegato 30 anni...
Il mondo piange Gladys West, la matemati...
Tomb Raider: Catalyst, il cast si allarg...
Renault Group chiude un ottimo 2025: Dac...
A questo prezzo la Blink Mini è difficil...
DJI Mini 4 Pro Fly More a 859€ su Amazon...
realme P4 Power avrà una batteria...
Marathon: data di uscita, edizioni e tut...
Dojo 3 riparte: Tesla affida a Intel il ...
Smartphone e attenzione in frantumi: Mat...
Aerei costruiti da robot umanoidi? L'eur...
Chery prende tutti in contropiede: batte...
Il colpo silenzioso di Intel: arriva l'u...
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: 10:49.


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