Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-05-2010, 19:19   #1
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
[SQL] Problema con la CREATE TABLE...

Salve ho un problema nella realizzazione di un database, evitando di postare qui tutto lo schema faccio un semplice esempio.

Supponiamo di avere un diagramma ER con l'entità "ENT" ed una sua relazione "REL" e che la cardinalità di partecipazione sia (1,n), traducendo nello schema relazionale si ha:

REL (idEntità, .. )
foreign key: REL[idEntità] incluso in ENT[id]

ENT(id, ..)
include: ENT[id] incluso in REL[idEntità] (Questo perchè partecipa con cardinalità minima 1 alla relazione)

Quando vado a creare queste tabelle in sql se creo prima la tabella REL mi da errore perché non può creare la foreign key visto che ENT ancora non è stata creata, se creo prima ENT mi da errore perché non può creare la inclusione visto che REL ancora non è stata creata.

Come faccio a creare il database in questi casi?
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2010, 19:38   #2
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Puoi creare le due tabelle senza i REFERENCES e poi fare una cosa tipo:
Codice:
alter table Prenotazioni add constraint FKRegistra_FK
     foreign key (username)
     references Accounts ON DELETE CASCADE;
Dove username è l'attributo che diventa foreign key mentre Accounts è l'altra tabella.

EDIT: Mi sa che ho letto male... Stai modellando una relazione 1-n con una tabella? Quindi una tabella per la relazione e 2 per le entità? Se si stai sbagliando.

Ultima modifica di Kenger : 25-05-2010 alle 19:41.
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2010, 20:26   #3
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Grazie per la risposta, ora provo a fare l'alter table!
Sto modellando 2 entità ed una relazione con un totale di 3 tabelle.
Nell'esempio che ho fatto prima ho preso solo l'entità e la relazione di interesse.
Una entità partecipa alla relazione con cardinalità (1,n) l'altra con cardinalità (0,n). Mi sembra corretto usare 3 tabelle in cosa sto sbagliando? Non ci sono entità che partecipano alla relazione con cardinalità (1,1).
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2010, 11:14   #4
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Ho un altro problema, come faccio a scrivere in sql un vincolo di inclusione?
Sto usando postgresql e scrivendo alla fine:

Codice:
ALTER TABLE entity ADD CONSTRAINT entityincludecheck CHECK (Login in (Select Login from relation))
mi da il seguendo errore:
Codice:
Error code 0, SQL state 0A000: ERROR: cannot use subquery in check constraint
Mi sembra strano perché tale notazione (con la select all'interno del check) l'ho trovata proprio su un libro (che però se non sbaglio usa oracle come db).

Come faccio a scrivere questo vincolo in postgresql?

Per quanto riguarda l'errore di prima, quello relativo alla cardinalità (1,n) sto sbagliando o avevi capito male tu dalla mia prima spiegazione? Se sto sbagliando mi spieghi perché?
Grazie!
Player1 è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2010, 18:51   #5
Johnn
Senior Member
 
Iscritto dal: May 2004
Messaggi: 1136
Ma per vincolo cosa intendi, la chiave esterna?

Se sì, penso che ti serva questo:

http://www.postgresql.org/docs/8.4/s...CONSTRAINTS-FK
Johnn è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2010, 21:51   #6
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Con vincolo intende i CHECK in fase di creazione e l'ultima volta che ho guardato (4 mesi fa circa) postgreSQL non li supporta.

Le relazioni (1,n)-(1,n) solitamente si modellano con 3 tabelle ma le tabelle dalla parte della n non importano nessuna chiave. Solo la tabella della relazione importa le chiavi.
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 27-05-2010, 10:51   #7
Player1
Senior Member
 
Iscritto dal: Feb 2002
Messaggi: 1370
Quote:
Originariamente inviato da Kenger Guarda i messaggi
Con vincolo intende i CHECK in fase di creazione e l'ultima volta che ho guardato (4 mesi fa circa) postgreSQL non li supporta.

Le relazioni (1,n)-(1,n) solitamente si modellano con 3 tabelle ma le tabelle dalla parte della n non importano nessuna chiave. Solo la tabella della relazione importa le chiavi.
Grazie mille, era esattamente questo il problema.
Quindi cosa dovrei fare? Devo fare i controlli direttamente dall'applicazione (in questo caso in php) o postgresql fornisce qualche altro costrutto differente come ad esempio di trigger e delle funzioni plpgsql?
Tra l'altro anche in questo caso ho un altro dubbio:
Se ho una semplice generalizzazione che da "Persona" va a "Uomo" e "Donna" e voglio inserire ad esempio i dati relativi ad un uomo, se inizio facendo una insert nella tabella "Uomo" viene segnalato un errore perché non ho ancora inserito i dati in "Persona" e viene violata la foreign key. Se inizio ad inserire i dati nella tabella "Persona" dovrebbe essere comunque segnalato un errore poiché esiste il vincolo dovuto alla generalizzazione completa che Persona = Uomo unito Donna e non ho ancora inserito i dati nella tabella "Uomo", qualunque sia il metodo (check, trigger o altro) con cui definisco quest'ultimo vincolo.
Mi daresti qualche chiarimento per favore?
Player1 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
'Artificial General Engineer': l'IA di J...
Il drone NASA Dragonfly, che voler&agrav...
Stop immediato a Fable 5 e Mythos 5: il ...
"Prime Day Amazon il 23-26 giugno": sì e...
Oggi 2 super MacBook Pro M5 e M5 Pro, 24...
Tineco Floor One Station S9 Artist: il s...
Raggiunte nuove altitudine e velocit&agr...
Apple Watch Series 11 GPS a 339€ su Amaz...
Come un MacBook, ma con la RTX 5070: MSI...
Paolo Zaccardi: "Smettere di assume...
Finalmente a buon prezzo 2 mini PC con R...
Samsung Galaxy Watch 7: uno crolla a 146...
NVIDIA pronta al 'piano B' per la Cina: ...
Xiaomi TV A Pro 55 a soli 366€: è...
No, i tuoi dati di Pokémon Go non sono f...
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: 11:15.


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