Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-10-2010, 12:05   #1
lorixillo
Member
 
Iscritto dal: Sep 2010
Messaggi: 81
[SQL] update per campi di tipo data

salve a tutti.
a causa di un errore in un "antico" database, tutte le date riferite all'anno 2000 (solo il 2000, non 2001,2002,... ecc) vengono rappresentate come 1900.
ho importato tutto in access ed ora devo trovare una query per cambiare ogni data con l'anno 1900 in una data con l'anno 2000.
avevo pensato a qualcosa del tipo:

Codice:
UPDATE PROVA SET data = 'day(data)-month(data)-2000'
WHERE year(Data)=1900;
access però mi dà errore di formattazione dati e, se scelgo di continuare con l'esecuzione, mi cancella totalmente i campi data del 1900.
sapreste indicarmi una query esatta equivalente?
grazie mille.

Loris

PS: se conoscete una "bibbia online" di sql potreste segnalarmela? grazie
lorixillo è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 12:38   #2
Kralizek
Senior Member
 
L'Avatar di Kralizek
 
Iscritto dal: Feb 2003
Città: Stockholm (SE)
Messaggi: 1343
non ho access sotto mano ma su SQL Server (che dovrebbe avere lo stesso engine di access da access 2007 in poi) questo va bene:

Codice:
DECLARE @Date DATETIME = '1900-12-10'
PRINT @Date

DECLARE @Date2 DATETIME;

SET @Date2 = 
CAST(
'2000'
+RIGHT('0' + CAST(MONTH(@Date) AS varchar(2)), 2)
+RIGHT('0' + CAST(DAY(@Date) AS varchar(2)), 2)
AS datetime)

PRINT @Date2
Se intendi lavorare su mssql/access, questo potrebbe interessarti: http://msdn.microsoft.com/en-us/library/bb500155.aspx
Kralizek è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 12:42   #3
rbon
Member
 
L'Avatar di rbon
 
Iscritto dal: May 2010
Messaggi: 66
Ciao,
SQL online:
1. Tutorial http://www.w3schools.com/sql/default.asp
2. Tutorial http://infogoal.com/sql/index.htm
rbon è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 13:14   #4
lorixillo
Member
 
Iscritto dal: Sep 2010
Messaggi: 81
@Kralizek: ma questo codice è SQL? °_°"
comunque non funziona... non riconosce declare
inoltre questo codice mi è completamente nuovo!
mi servirebbe l'equivalente corretto della mia query (una UPDATE, insomma)
mi spiegheresti il codice che hai scritto? grazie mille!

@rbon: grazie, mi saranno utili!
lorixillo è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 13:45   #5
Kralizek
Senior Member
 
L'Avatar di Kralizek
 
Iscritto dal: Feb 2003
Città: Stockholm (SE)
Messaggi: 1343
Quote:
Originariamente inviato da lorixillo Guarda i messaggi
@Kralizek: ma questo codice è SQL? °_°"
comunque non funziona... non riconosce declare
inoltre questo codice mi è completamente nuovo!
mi servirebbe l'equivalente corretto della mia query (una UPDATE, insomma)
mi spiegheresti il codice che hai scritto? grazie mille!

@rbon: grazie, mi saranno utili!
era il codice necessario per calcolare il valore, poi sarebbe stato a te inserirlo correttamente nella query di update

Ecco la query dell'update
Codice:
UPDATE Prova SET Data = CAST('2000' + RIGHT('0' + CAST(MONTH(Data) AS varchar(2)), 2) + RIGHT('0' + CAST(DAY(Data) AS varchar(2)), 2) AS DATETIME) 
WHERE YEAR(Data) = 1900
Kralizek è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2010, 14:03   #6
lorixillo
Member
 
Iscritto dal: Sep 2010
Messaggi: 81
ah, ok!
ora però ottengo un errore riferito ad "AS"...
ma varchar() è una funzione di sql? °_°
e cast? non le trovo nei manuali che mi avete segnalato :S

grazie!

edit: AAAAAAAAAAAAAAAAA!
è spuntato un ulteriore problema, uno di quei problemi più odiosi che spuntano fuori quando il resto va bene, ti fanno perdere un mucchio di tempo, e sono dovuti ad insulse formattazioni.
devo dare un nuovo numero ad una certa riga data una specifica data (perdonate il giro di parole)

UPDATE DONAZIONE SET Numero=9 WHERE IdDonatore=7029 AND Data=4/2/2015

ebbene, ho provato con doppi apici, apici singoli, inversioni di campi, aggiunte di zeri...
non ne vado fuori, non vuole funzionare!
in più non trovo alcun esempio di update con date nel campo where in internet!
sapreste indicarmi una guida sulle date e le formattazioni in particolare?
le precedenti guide non le approfondiscono purtroppo...

grazie ancora

Loris

Ultima modifica di lorixillo : 04-10-2010 alle 20:47. Motivo: problemi, problemi ed ancora problemi!!!
lorixillo è offline   Rispondi citando il messaggio o parte di esso
Old 05-10-2010, 17:18   #7
lorixillo
Member
 
Iscritto dal: Sep 2010
Messaggi: 81
up :'(

risolto l'ultimo problema, ci andavano i cancelletti e il giorno e il mese andavano invertiti...
non capisco mai come formattare ste date, ogni campo ha un modo diverso di operare... bah!
rimane aperto il problema da 1900 a 2000, cercasi poveretto in grado di aiutarmi

Ultima modifica di lorixillo : 05-10-2010 alle 18:47.
lorixillo è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2010, 13:56   #8
lorixillo
Member
 
Iscritto dal: Sep 2010
Messaggi: 81
ho risolto i miei problemi!

posto comunque la soluzione, così che il prossimo "fortunato" con gli stessi miei dubbi possa risolverli:

primo problema: per inserire una data in una clausola where di una query di update è necessario
scriverla nel formato mese/giorno/anno e circondarla di # (non chiedetemi perchè, questa storia risulta nuova anche a me...)
esempio: 19 settembre 1965: #09/19/1965# oppure funziona anche senza gli zeri, ovvero: #9/19/1965#

secondo problema: per modificare le date con l'anno 2000 la seguente query funziona:

Codice:
UPDATE DONAZIONE SET data = DateValue(day(data) & '/' & month(data) & '/2000') WHERE year(Data)=1900
& è usato per concatenare le stringhe e DateValue(stringa) converte la stringa al suo interno in una data valida.

la sola cosa che mi fa incazzare è che ho trovato l'operatore "&" in yahoo answers e la funzione "DateValue(stringa)" su un altro sito a caso: dico io, la guida in linea di access o qualsiasi altro manuale trovato in giro non dovrebbero spiegarle, ste cose??
la mia preoccupazione ora è trovare una documentazione solida su sql e una spiegazione sulle varie versioni e dove sono implementate.
non capisco inoltre quali funzioni appartengono a quale linguaggio e a quale programma! ad esempio il codice di Kralizek da dove spunta fuori? xD

grazie a tutti, alla prossima
Loris
lorixillo è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2010, 14:55   #9
Kralizek
Senior Member
 
L'Avatar di Kralizek
 
Iscritto dal: Feb 2003
Città: Stockholm (SE)
Messaggi: 1343
il mio codice é TSQL ovvero l'SQL di Sql Server di Microsoft

per curiositá che versione di Access stai usando?
Kralizek è offline   Rispondi citando il messaggio o parte di esso
Old 06-10-2010, 15:20   #10
lorixillo
Member
 
Iscritto dal: Sep 2010
Messaggi: 81
access 2007

quindi funzioni come cast o varchar dovrebbero essere riconosciute dato che anche access è di microsoft...
lorixillo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Il data center del futuro secondo Huawei...
Spesa a domicilio senza conducente: robo...
Satoshi Nakamoto ha finalmente un volto?...
La Corea del Sud taglia fuori i bus elet...
GoPro taglia ancora: licenziato il 23% d...
Muse S Athena: la fascia che ti legge ne...
PS5 Pro e PSSR 2.0: tutti i giochi compa...
Dimensity 9600 Pro promette prestazioni ...
BMW i7 2026 adotta celle cilindriche Gen...
Cyberpunk 2077 si aggiorna su PS5 Pro co...
Valve porta Steam Link su Vision Pro per...
Google Maps: ufficiali 3 novità c...
TikTok punta tutto sull'Europa: un milia...
OnePlus Nord 6 ufficiale: arriva con una...
Google lancia di nascosto un'app AI che ...
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: 16:07.


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