Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-03-2015, 18:43   #1
digital_brain
Senior Member
 
L'Avatar di digital_brain
 
Iscritto dal: Jan 2003
Città: Roma Messaggi Totali:50333
Messaggi: 3519
[MySql] Query su intervallo di date

Ciao a tutti,
ho un problema con una query che mi sta facendo dannare...
devo tirare fuori da una tabella dei valori che corrispondono ad un intervallo di giorni (da inizio mese a ieri).
le ho provate tutte ma l'interrogazione mi include anche alcuni giorni del mese precedente pur avendogli dato come intervallo ben definito dal 1/03/2015 al 31/03/2015.
la query è la seguente:
Codice:
SELECT `COL 6` FROM `realtime_es3` WHERE `COL 4` = 'Attiva' AND `COL 6` < DATE_FORMAT (now(),'%e/%m/%Y') and `COL 6` between '01/03/2015' and '31/03/2015'
quello che mi restituisce la query sono giustamente i giorni dal 1 al 9/03 ma anche i giorni 8-9 e 10/2....come è possibile????

se semplifico la query così
Codice:
SELECT `COL 6` FROM `realtime_es3` WHERE `COL 4` = 'Attiva' AND `COL 6`  between '01/03/2015' and '31/03/2015'
addirittura mi stampa tutti i giorni presenti nella tabella ignorando completamente il between.

Pensavo che il problema potesse essere il fatto che il tipo della colonna data è varchar, ma anche facendo un cast a DATE mi restituisce null.

Grazie in anticipo!
__________________
Photo: Nikon D80 - Nikon 105Vr Micro + Nikon 70-300Vr + 18-135 + 50mm 1.8 + F65 + Canon S3 Is + Casio S600
Pc: Amd X2 6400+ - Asus M2N SLI Deluxe - 4 x 1Gb Corsair XMS2 800mHz cas 4 - Ati Hd 2600 Xt 512Mb ddr3 - Case TT Armor-Coolpanel2 Utenti con cui ho trattato
digital_brain è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2015, 22:00   #2
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Il tipo di dato di `COL 6` è VARCHAR? E contiene solo date formattate "alla europea", giusto?

Perché questa scelta molto poco felice? Perché un nome scomodo che non identifica il contenuto? Per finire, perché 'Attiva' in `COL 4` non è un INT o TINYINT?

Lavorando molto poco efficientemente sui dati grezzi penserei a una cosa del genere:
Codice:
SELECT `COL 6`
FROM `realtime_es3`
WHERE `COL 4` = 'Attiva'
   AND STR_TO_DATE(`COL 6`,'%d/%m/%Y') < NOW()
   AND STR_TO_DATE(`COL 6`,'%d/%m/%Y') BETWEEN '2015-03-01' AND '2015-03-31'
Se si desidera escludere anche la giornata odierna con < NOW(), la soluzione che m'è venuta in mente è questa:
Codice:
SELECT `COL 6`
FROM `realtime_es3`
WHERE `COL 4` = 'Attiva'
   AND ADDTIME( STR_TO_DATE(`COL 6`,'%d/%m/%Y'), '23:59:59.999') < NOW()
   AND STR_TO_DATE(`COL 6`,'%d/%m/%Y') BETWEEN '2015-03-01' AND '2015-03-31'
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2015, 22:40   #3
digital_brain
Senior Member
 
L'Avatar di digital_brain
 
Iscritto dal: Jan 2003
Città: Roma Messaggi Totali:50333
Messaggi: 3519
Che dirti....sei un grande!!!Grazie!!!ho fatto solo una prova veloce ma pare che funziona...il mio errore era nel dare a between gli intervalli con le date in formato europeo anzichè americano?
__________________
Photo: Nikon D80 - Nikon 105Vr Micro + Nikon 70-300Vr + 18-135 + 50mm 1.8 + F65 + Canon S3 Is + Casio S600
Pc: Amd X2 6400+ - Asus M2N SLI Deluxe - 4 x 1Gb Corsair XMS2 800mHz cas 4 - Ati Hd 2600 Xt 512Mb ddr3 - Case TT Armor-Coolpanel2 Utenti con cui ho trattato
digital_brain è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2015, 21:38   #4
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Varie incomprensioni sovrapposte:
  • le colonne contengono stringhe con una formattazione che MySQL non si aspetta
  • è necessario spiegargli come convertirle in un tipo di dato confrontabile con le condizioni che si desidera applicare (DATETIME, in questo caso però privo di time), quindi ho scelto STR_TO_DATE
  • avendo scritto le condizioni con la stessa formattazione inattesa MySQL s'è inventato qualcosa per interpretarle, ma non c'ha azzeccato
Il formato che si aspetta normalmente MySQL nelle condizioni è ISO 8601, di solito uno di questi:
  • aaaa-mm-gg
  • aaaa-mm-gg hh:mm:ss
  • aaaa-mm-gg hh:mm:ss.mmm
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 12-03-2015, 17:25   #5
digital_brain
Senior Member
 
L'Avatar di digital_brain
 
Iscritto dal: Jan 2003
Città: Roma Messaggi Totali:50333
Messaggi: 3519
Grazie mille!
__________________
Photo: Nikon D80 - Nikon 105Vr Micro + Nikon 70-300Vr + 18-135 + 50mm 1.8 + F65 + Canon S3 Is + Casio S600
Pc: Amd X2 6400+ - Asus M2N SLI Deluxe - 4 x 1Gb Corsair XMS2 800mHz cas 4 - Ati Hd 2600 Xt 512Mb ddr3 - Case TT Armor-Coolpanel2 Utenti con cui ho trattato
digital_brain è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
Il cofondatore di Netflix ha lasciato l'...
ASUS porta in Italia il nuovo Zenbook Du...
Assassin's Creed: Black Flag Resynced, s...
Xbox Game Pass cambierà: tra le n...
I nuovi Surface Pro e Laptop sono vicini...
OnePlus ci riprova con la fascia bassa: ...
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: 12:22.


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