Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-02-2016, 16:15   #1
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
[MySQL] "Sicronizzare" due tabelle tramite il campo di relazione

Ciao a tutti voi.

Ho la necessita di "sincronizzare" due tabelle:

ESEMPLARI
id, etc....

EXPO
id, id_esemplari

Diciamo che:
- ESEMPLARI e' la tabella madre con "id" chiave primaria
- EXPO e' in relazione con la tabella ESEMPLARI tramite la colonna id_esemplari

Io vorrei che tutti gli id di ESEMPLARI siano contenuti in id_esemplari di EXPO.

Al momento invece ho una situazione anomala:
1) non tutti gli id di ESEMPLARI sono contenuti in id_esemplari di EXPO
2) su EXPO sono presenti id_esemplari che non trovano una corrispondenza in EXPO.

Come potrei riallineare il tutto?

Grazie.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2016, 16:41   #2
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Non capisco la tua affermazione.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2016, 16:54   #3
DoctorT
Senior Member
 
Iscritto dal: Jul 2005
Messaggi: 737
penso di aver capito quello che vorresti fare, tecnicamente "sincronizzare" significa creare un vincolo di integrità referenziale tra 2 tabelle del database.

in MySQL questo si fà inserendo una FOREIGN KEY al momento della creazione della tabella ... ti posto questo esempio preso paro para da W3schools spero sia comprensibile:

Codice:
CREATE TABLE Orders
(
O_Id int NOT NULL,
OrderNo int NOT NULL,
P_Id int,
PRIMARY KEY (O_Id),
FOREIGN KEY (P_Id) REFERENCES Persons(P_Id)
)
in pratica poi dovresti gestire anche gli errori del DBMS che si generano quando tenti di cancellare e/o modificare una FOREIGN KEY
__________________
O.S.: WIN 10 64-bit CPU: INTEL I5 12400F RAM: 16 GB Corsair Vengeance LPX 3200 Mhz VGA: MSI ARMOR RX570 4GB OC MOBO: ASROCK B660M PRO RS HDD: Seagate 1TB SDD: CRUCIAL MX500 500GB ALI: BE QUIET PURE POWER CM 11 600W
DoctorT è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2016, 01:21   #4
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Alla fine ho risolto tramite queste due query:

Codice:
-- Ho rimosso le righe contenenti gli ID_ESEMPLARI non presenti nella tabella ESEMPLARI
DELETE FROM expo_westie 
WHERE NOT EXISTS(SELECT NULL
FROM esemplari f
WHERE f.id = id_esemplari)
                 
-- Ho inserito gli ID della tabella ESEMPLARI non presenti nella tabella EXPO_WESTIE
INSERT INTO expo_westie (id_esemplari)
SELECT id 
FROM esemplari
WHERE id NOT IN (
SELECT id_esemplari 
FROM expo_westie
)
Magari sarebbe meglio usare una foreign key, vero?
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2016, 19:53   #5
DoctorT
Senior Member
 
Iscritto dal: Jul 2005
Messaggi: 737
Quote:
Originariamente inviato da robertino_salemi Guarda i messaggi
Alla fine ho risolto tramite queste due query:

...
Magari sarebbe meglio usare una foreign key, vero?
dipende, intanto bisogna vedere se nella relazione logica tra le 2 tabelle questa integrità deve essere mantenuta e per fare questo dovremmo conoscere il modello che hai voluto rappresentare nel tuo database.

Inoltre la tua soluzione potrebbe generare un programma che funziona correttamente ma è meno "robusto" cioè è più facile che quando viene modificato generi errori.

In ogni caso direi che è bene imparare ad usare le FOREGN KEY e a capire quando bisogna inserirle nelle nostre tabelle.
__________________
O.S.: WIN 10 64-bit CPU: INTEL I5 12400F RAM: 16 GB Corsair Vengeance LPX 3200 Mhz VGA: MSI ARMOR RX570 4GB OC MOBO: ASROCK B660M PRO RS HDD: Seagate 1TB SDD: CRUCIAL MX500 500GB ALI: BE QUIET PURE POWER CM 11 600W
DoctorT è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 11:17   #6
Hellzakk
Member
 
Iscritto dal: Nov 2006
Messaggi: 210
quoto DoctorT, mi piacerebbe capire a cosa ti serve questa relazione
Hellzakk è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 12:14   #7
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Quote:
Originariamente inviato da Hellzakk Guarda i messaggi
quoto DoctorT, mi piacerebbe capire a cosa ti serve questa relazione
In che senso?
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 12:17   #8
Hellzakk
Member
 
Iscritto dal: Nov 2006
Messaggi: 210
a cosa ti serve avere una tabella con riferimenti alle primary key di una sulle primary key di un'altra
Hellzakk è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 12:19   #9
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
La connessione non e[ tra due PRIMARY KEY.

Io devo relazionare
ESEMPLARI > id (PRIMARY KEY)

EXPO > id_esemplari (NO PRIMARY KEY)
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 12:32   #10
Hellzakk
Member
 
Iscritto dal: Nov 2006
Messaggi: 210
mi sono spiegato male, su EXPO avrai una sua primary key con il campo id_esemplari che certamente non è primary key ma che deve avere lo stesso valore della primary key di ESEMPLARI... ho capito bene?

se si non ho capito a cosa ti può servire...
Hellzakk è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 14:15   #11
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Esatto, giusto!
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 17:32   #12
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Devo capire come usarle, fino ad oggi non ne ho mai fatto uso.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2016, 23:41   #13
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Auto ditatta....
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2016, 08:18   #14
Hellzakk
Member
 
Iscritto dal: Nov 2006
Messaggi: 210
Scusa se ripeto per l'ennesima volta la stessa domanda, ma qualè lo scopo di avere 2 tebelle così composte?

Non lo chiedo per farmi gli affari tuoi, ma per capire se ci può essere un metodo migliore.
Hellzakk è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2016, 12:04   #15
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Quote:
Originariamente inviato da Hellzakk Guarda i messaggi
Scusa se ripeto per l'ennesima volta la stessa domanda, ma qualè lo scopo di avere 2 tebelle così composte?

Non lo chiedo per farmi gli affari tuoi, ma per capire se ci può essere un metodo migliore.
Inizialmente e' nata la tabella ESEMPLARI con PRIMARY KEY id

Successivamente per tali esemplari e' nata l'esigenza di inserire dei risultati nelle Esposizioni con diverse informazioni.
Cosi' e' stata creata la tabella EXPO con PRIMA KEY id e messe in relazione con la tabella ESEMPLARI tramite la colonna id_esemplari.


Quote:
Originariamente inviato da coffe_killer Guarda i messaggi
Allora mi sa che ti mancano proprio delle nozioni base.
Fermo restando che questi argomenti richiedono tanto studio teorico, il non sapere cosa siano e come si rispettino i vincoli referenziali denota lacune da colmare il prima possibile.
Dovrei approfondire molto l'argomento.
Alcuni consigli in merito? Tutorial da linkarmi?

Grazie.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2016, 13:16   #16
Hellzakk
Member
 
Iscritto dal: Nov 2006
Messaggi: 210
Quote:
Originariamente inviato da robertino_salemi Guarda i messaggi
Inizialmente e' nata la tabella ESEMPLARI con PRIMARY KEY id

Successivamente per tali esemplari e' nata l'esigenza di inserire dei risultati nelle Esposizioni con diverse informazioni.
Cosi' e' stata creata la tabella EXPO con PRIMA KEY id e messe in relazione con la tabella ESEMPLARI tramite la colonna id_esemplari.
Quindi nella tabella EXPO non sarà presente solamente id ed id_esemplari ma anche altri attributi e giustamente non hai scelto di aggiungere altri campi alla tabella ESEMPLARI perchè hai più esposizioni per ogni esemplare, giusto?
Hellzakk è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2016, 13:59   #17
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Esatto, all'inizio avrei dovuto avere piu' esposizioni, dopo invece la corrispondenza tra le due tabelle e diventata di
1 a 1.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2016, 17:54   #18
Hellzakk
Member
 
Iscritto dal: Nov 2006
Messaggi: 210
Se e' 1 a 1 non ti conviene alterare la tabella ESEMPLARI aggiungendo gli attributi che ti servono?

Presumo che le esportazioni le leggi ogni volta che leggi esemplari, raddoppiando il costo di lettura inutilmente..
Hellzakk è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2016, 18:14   #19
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Eh lo so, ma si tratta di un progetto alquanto vecchio, tutto e' cambiato in corso d'opera e quindi....

Ne faro' tesoro per la prossima volta.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Zscaler Threat Report 2026: l'adozione d...
Claude AI minaccia omicidi e ricatti qua...
Dentro la gara: a Milano Cortina 2026 i ...
Samsung Display presenta QD-OLED Penta T...
KONAMI torna con "Silent Hill: Town...
Rende il citofono smart a 44,99€: Ring I...
ThunderX3 XTC, la sedia da ufficio che s...
Mercy, Mission Impossible, Aronofsky: il...
Project Windless: il nuovo action in esc...
Saros: mostrato il gameplay del gioco de...
God of War: Sons of Sparta annunciato e ...
John Wick torna in un nuovo videogioco a...
MADE chiude il 2025 con 59 partner e 250...
007 First Light: allo State of Play un n...
Gli iPhone su Amazon costano meno che su...
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: 04:14.


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