Torna indietro   Hardware Upgrade Forum > Software > Programmazione

 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-10-2010, 09:02   #1
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
[Database] Id esterno che punta a più tabelle

Mi trovo sempre di fronte al problema di come poter rappresentare al meglio una situazione in cui una tabella possa essere collegata a più tabelle tramite lo stesso campo.
Ad esempio ho una tabella generica per la descrizione dello stato di un servizio, e voglio legare questa tabella con le informazioni del servizio.
Ovviamente ogni servizio ha i propri dati e quindi ha una propria tabella.
Dato che nuovi servizi vengono aggiunti frequentemente e che comunque sono abbastanza numerosi (avere una trentina di chiavi esterne non mi sembra il massimo), la soluzione al momento è di avere una tabella TabellaServizi di appoggio contenente i valori Id-NomeTabella e nella tabella Servizi generica avere 2 colonne una con FK verso TabellaServizi e l'altra con Id non legato da alcun vincolo referenziale ma che indica l'Id del servizio vero e proprio. Per il recupero dei dati utilizzo viste specifiche che eseguono la join con la tabella indicata in TabellaServizi, perchè ovviamente le ricerche avvengono contestualmente ad un solo servizio.

Qualcuno ha una soluzione migliore?
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 09:41   #2
Kralizek
Senior Member
 
L'Avatar di Kralizek
 
Iscritto dal: Feb 2003
Città: Stockholm (SE)
Messaggi: 1343
non sono sicuro di aver capito esattamente il tuo problema, ma se non ho capito totalmente un'altra cosa, forse questo puó esserti utile anche se in realtá questa soluzione é una traduzione di una gerarchia di classi.

Codice:
CREATE TABLE [Types]
(
	ID INT NOT NULL PRIMARY KEY,
	Name NVARCHAR(64) NOT NULL
)

CREATE TABLE BaseClass
(
	ID INT NOT NULL PRIMARY KEY IDENTITY (1,1),
	FKTypeID INT NOT NULL REFERENCES [Types](ID),
	UNIQUE (ID, FKTypeID)
	-- Additional base class fields here
)

CREATE TABLE SubClass1
(
	FKBaseID INT NOT NULL REFERENCES BaseClass(ID),
	FKTypeID AS (1) PERSISTED NOT NULL,
	FOREIGN KEY (FKBaseID, FKTypeID) REFERENCES BaseClass(ID, FKTypeID)
	-- Specific fields here
)

CREATE TABLE SubClass2
(
	FKBaseID INT NOT NULL REFERENCES BaseClass(ID),
	FKTypeID AS (2) PERSISTED NOT NULL,
	FOREIGN KEY (FKBaseID, FKTypeID) REFERENCES BaseClass(ID, FKTypeID)
	-- Specific fields here
)
Kralizek è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 10:16   #3
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
puoi fare un esempio pratico in modo da inquadrare bene il dominio del problema?
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 10:25   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
In parte si. Fondamentalmente è una gerarchia di classi che estendono la classe base che contiene solo le informazioni comuni.
Il problema è che altre entità del database (es ordini, utenti ecc.) fanno riferimento solo alla tabella base, quindi è questa che deve essere legata alle "tabelle derivate" per consentire di recuperare i dettagli del servizio.
tomminno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
Grand Theft Auto VI arriva su Amazon al ...
GTA 6, dubbi sulla modalità 'Perf...
Braun in offerta su Amazon: rasoi elettr...
Microsoft aggiorna ancora la gamma Surfa...
Tesla Semi coinvolto nel suo primo incid...
'Si. Può. Fare!': i ricercatori h...
HONOR Magic V6 ufficiale in Italia: la r...
Sicilia da record: entra in funzione F&e...
Apple taglia la produzione di iPhone 17:...
Pioggia di sconti nuovi, ecco la TOP 10 ...
Amazon Haul rilancia le promo dedicate a...
Componenti PC in offerta su Amazon: GeFo...
Meta si prepara a sbarcare nel cloud per...
Windows 11: Microsoft spiega perché le G...
WhatsApp Plus arriva in Italia, come fun...
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:02.


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