Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-01-2013, 18:14   #1
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15648
[DB] - Valore null

Salva ho una curiosità riguardo il valore null nei dataBase.
La cosa che mi chiedevo è: se in un textbox ho l'assenza di informazioni, finora faccio memorizzare nel DB una stringa vuota (nei campi di tipo string) e "null" nei campi di tipo numerico. Per il DB è più "leggero" gestire il valore null piuttosto del ""?
Quando ho una tabella con oltre 300.000 righe avrei qualche vantaggio nell'avere i campi con "null" piuttosto che ""?
Spero di essermi saputo spiegare, grazie
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2013, 19:17   #2
idoido
Senior Member
 
Iscritto dal: May 2008
Messaggi: 429
normalmente i dbms per gestire i campi che tu definisci nullable aggiungono un bit per dire se è memorizzato null oppure no.

sta a te decidere se un campo string accetta null oppure no, dipende dalla logica della tua applicazione, però se accetti null hai 3 "stati"
NULL
stringa vuota
e stringa con n caratteri

una stringa vuota è diverso da NULL, quindi se il campo non lo fai nullable hai meno controlli da eseguire.

riguardo alla leggerezza del db, si dovrebbero eseguire dei test, ma dubito che con 300.000 righe puoi notare delle differenze in termini di prestazioni (poi se hai delle query con outer join tra più tabelle è un altro paio di maniche)
idoido è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2013, 21:01   #3
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15648
Quote:
Originariamente inviato da idoido Guarda i messaggi
normalmente i dbms per gestire i campi che tu definisci nullable aggiungono un bit per dire se è memorizzato null oppure no.

sta a te decidere se un campo string accetta null oppure no, dipende dalla logica della tua applicazione, però se accetti null hai 3 "stati"
NULL
stringa vuota
e stringa con n caratteri

una stringa vuota è diverso da NULL, quindi se il campo non lo fai nullable hai meno controlli da eseguire.

riguardo alla leggerezza del db, si dovrebbero eseguire dei test, ma dubito che con 300.000 righe puoi notare delle differenze in termini di prestazioni (poi se hai delle query con outer join tra più tabelle è un altro paio di maniche)
Ciao, forse non ho ben distinto l'assenza di informazioni... in ogni faccio molto uso di join con 6-8 tabelle la volta, per un totale di mezzo milione di record..
Credi che a livello di "leggerezza" non cambi nulla?
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 01-01-2013, 21:35   #4
idoido
Senior Member
 
Iscritto dal: May 2008
Messaggi: 429
ora non vorrei scrivere una cazzata e non so quale dbms stai usando.

ma con un campo string nullable

se ad esempio hai i valori sui campi id, valore

1, [NULL]
2, ''
3, 'questa è una stringa non vuota'

facendo una query del tipo SELECT * FROM tabella1 WHERE valore == '' ti dovrebbe restituire solo il record con id 2

EDIT:
riguardo ai join che fai, se sono di tipo INNER JOIN con clausole di tipo uguale non farti troppi problemi, ma join tra 6 tabelle forse sono indice di una struttura non ottimizzata, dipende sempre dal dominio dell'applicazione
idoido è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2013, 17:29   #5
Enriko81
Senior Member
 
Iscritto dal: Sep 2005
Messaggi: 1677
a livello teorico mettere un null vuol dire che non sai cosa inserirci, se metti una stringa vuota è un update dove diciamo che azzeri un valore stringa predentemente inserito....
tuttavia se il database non è coerente e proviene da terze parti potresti trovarti colonne stringhe vuote e null sui campi "ignoti", in tal caso sai gia che è meglio fare un controllo con un "or" nel where della select.
Enriko81 è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2013, 20:38   #6
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15648
Ma come è meglio gestire l'assenza di informazioni? Memorizzo una stringa vuota o null? Possibile che a livello di prestazioni non cambi nulla?

Inviato dal mio GT-I9300 con Tapatalk 2
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
ECOVACS mostra il futuro delle faccende ...
Prezzo shock per Samsung Galaxy S25 e S2...
Leon, Formentor e Terramar diventano 'ri...
DREAME Aqua10 Ultra Roller Complete e Mo...
Intel APO si aggiorna: supporto a 15 nuo...
CrowdStrike Threat Hunting Report 2025: ...
Polestar 5 in mostra a IAA. E il CEO chi...
Amazfit T-Rex 3 Pro sfida gli sport estr...
IFA 2025: LG presenta la nuova collezion...
Broadcom vuole vendere solo VMware Cloud...
A 389€ questo portatile tuttofare HP con...
Compra su Temu per 42€, riceve una multa...
Incentivi auto elettriche 2025: possibil...
2 tablet imbattibili: quello da 99€ bast...
XPeng, da promessa a realtà tecno...
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:30.


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