Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Con la prima rete 5G Standalone attiva in Italia, WINDTRE compie un passo decisivo verso un modello di connettività intelligente che abilita scenari avanzati per imprese e pubbliche amministrazioni, trasformando la rete da infrastruttura a piattaforma per servizi a valore aggiunto
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro punta a diventare uno dei riferimenti assoluti nel segmento dei camera phone di fascia alta. Con un teleobiettivo Hasselblad da 200 MP, una batteria al silicio-carbonio da 7500 mAh e un display da 6,78 pollici con cornici ultra ridotte, il nuovo flagship non teme confronti con la concorrenza, e non solo nel comparto fotografico mobile. La dotazione tecnica include il processore MediaTek Dimensity 9500, certificazione IP69 e un sistema di ricarica rapida a 80W
DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-06-2005, 17:25   #1
thefrog
Senior Member
 
L'Avatar di thefrog
 
Iscritto dal: Feb 2003
Messaggi: 3532
[SQL] problema con foreign key....chi mi da una manina?

stò preparando un esame su sql

devo creare queste 2 tabelle ma non ho capito bene come funzionano ste foreign key e infatti mi da quest'errore:

Error | 1005 | Can't create table '.\cddb\artist.frm' (errno: 150)

il codice è questo:
Codice:
CREATE TABLE Artist 
	(artistid		INT(10) UNSIGNED AUTO_INCREMENT NOT NULL,
       name			CHAR (255) NOT NULL,
	 index (artistid, name), 
	 FOREIGN KEY (artistid, name) REFERENCES CD(artist,name), # ON UPDATE CASCADE,
	 countryid		CHAR (3) NOT NULL,
	 website		CHAR (255),
	 description	TEXT,
	 PRIMARY KEY (artistid)) ENGINE=INNODB;
show warnings;
INSERT INTO Artist(artistid,name,countryid,website,description) VALUES (NULL, 'The Chemical Brothers', 'UK', 'http://www.thechemicalbrothers.com', 'blablablablablabla');
INSERT INTO Artist(artistid,name,countryid,website,description) VALUES (NULL, 'Moby', 'USA', 'http://www.moby.com', 'blabla');
INSERT INTO Artist(artistid,name,countryid,website,description) VALUES (NULL, 'Skin', 'UK', 'http://www.skinmusic.net', 'blablabla');

show warnings;
CREATE TABLE CD (
	cdid	int(10) UNSIGNED AUTO_INCREMENT NOT NULL,
	artist	int(10) UNSIGNED NOT NULL,
	name		CHAR (255) NOT NULL,
	index (artist,name),
	FOREIGN KEY (artist, name) REFERENCES Artist(artistid, name),
	title		char(255) NOT NULL,
	label		char(255) NOT NULL,
	released	date NOT NULL,
	PRIMARY KEY (cdid)) ENGINE=INNODB;

INSERT INTO CD (artist,name,title,label,released) VALUES (NULL, 'The Chemical Brothers', 'Push the button', 'EMI', '2005-01-24');
qualcuno mi spiega cosa sbaglio con ste foreign key? su mysql.com non sono riuscito a capirlo :|

grazie mille
thefrog è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 17:30   #2
Brazorv
Member
 
Iscritto dal: Aug 2004
Messaggi: 156
FOREIGN KEY (artistid, name) REFERENCES CD(artist,name) ON UPDATE CASCADE,

forse così?
Brazorv è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 17:35   #3
thefrog
Senior Member
 
L'Avatar di thefrog
 
Iscritto dal: Feb 2003
Messaggi: 3532
Quote:
Originariamente inviato da Brazorv
FOREIGN KEY (artistid, name) REFERENCES CD(artist,name) ON UPDATE CASCADE,

forse così?
uhm...quello l'avevo commentato io, non c'entra nulla, mi ero scordato di toglierlo prima di postare sul forum
thefrog è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 17:37   #4
Brazorv
Member
 
Iscritto dal: Aug 2004
Messaggi: 156
già # forse è il caldo
Brazorv è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 17:41   #5
Brazorv
Member
 
Iscritto dal: Aug 2004
Messaggi: 156
cmq quella riga eliminala non serve
Brazorv è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 18:04   #6
Brazorv
Member
 
Iscritto dal: Aug 2004
Messaggi: 156
quando crei la tabella artista fai riferimento alla tabella cd che non è ancora stata creata, per cui mysql ti da quell'errore.
se vuoi legare la tabella cd ad artista, devi fare riferimento da cd ad artista, e non il contrario.
Brazorv è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 18:34   #7
thefrog
Senior Member
 
L'Avatar di thefrog
 
Iscritto dal: Feb 2003
Messaggi: 3532
l'ho levata e avevi ragione, ora da solo un errore, questo:

ERROR 1216 (23000): Cannot add or update a child row: a foreign key constraint fails
thefrog è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 18:45   #8
Brazorv
Member
 
Iscritto dal: Aug 2004
Messaggi: 156
nell'ultima riga quando inserisci i valori del cd non devi mettere NULL come artist id ma il valore esatto dell'id corrispondente nella tabella artist.
Un'altra cosa che ho notato ora è che in cd tu referenzi l'artista con artistid e name, puoi usare solo artistid perchè è la chiave di artist.
Prova così, io non ho un server mysql ora.
Brazorv è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 19:18   #9
thefrog
Senior Member
 
L'Avatar di thefrog
 
Iscritto dal: Feb 2003
Messaggi: 3532
Quote:
Originariamente inviato da Brazorv
nell'ultima riga quando inserisci i valori del cd non devi mettere NULL come artist id ma il valore esatto dell'id corrispondente nella tabella artist.
Un'altra cosa che ho notato ora è che in cd tu referenzi l'artista con artistid e name, puoi usare solo artistid perchè è la chiave di artist.
Prova così, io non ho un server mysql ora.
ma io vorrei che gli artist della tabella CD e artisti fossero automaticamente in realzione.....non so se si vede ma non ho tanto chiara sta cosa...

vorrei evitare chw quando uno inserisce un record nella tabella CD si debba "ricordare a memoria" l'ID dell'artista.

si può fare? cioè...sicuramente si ma forse sbaglio qualcosa concettualemente io
thefrog è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2005, 19:52   #10
Brazorv
Member
 
Iscritto dal: Aug 2004
Messaggi: 156
Quote:
Originariamente inviato da thefrog
ma io vorrei che gli artist della tabella CD e artisti fossero automaticamente in realzione.....non so se si vede ma non ho tanto chiara sta cosa...

vorrei evitare chw quando uno inserisce un record nella tabella CD si debba "ricordare a memoria" l'ID dell'artista.

si può fare? cioè...sicuramente si ma forse sbaglio qualcosa concettualemente io
Quello che vuoi fare tu si può fare a livello di applicativo.
Per esempio quando tu crei una pagina web (con php,asp,jsp...) per inserire i dati del cd, metti dei textfield per inserire i dati relativi al cd, poi metti un <select> per l'inserimento dell'artista. Fai una query così
SELECT artistid,name FROM artist;
fai visualizzare name nella lista e assegni artistid come value e prendi questo come valora per fare poi la insert nel database.
Brazorv è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi Wind Tre 'accende' il 5G Standalone in Italia: s...
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
HBM5, DDR6 e NAND da 400 layer: il futur...
'Aggiorna e arresta' non spegne ma riavv...
Ayaneo oltre le handheld: in arrivo uno ...
Progetto STELLAR: l'Europa punta sulle b...
L'auto cattura le sue stesse emissioni: ...
Hisense 55'' 4K Ultra HD 2025 in offerta...
Black Friday Xiaomi 2025: 5 offerte da n...
Apple si affida a Google? Gemini alla ba...
Gravidanze più facili? STAR, il s...
Startup cinesi di veicoli elettrici, ad ...
Volkswagen nella bufera...per il caff&eg...
Esaurito quello con Ryzen, ecco un altro...
Steam: gli utenti Linux sfondano la barr...
BYD nel terzo trimestre: utile netto sop...
Windows 11 verso un supporto Bluetooth p...
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: 13:16.


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