Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-06-2010, 12:50   #1
Maxti
Member
 
Iscritto dal: Mar 2010
Messaggi: 53
[C#] formato datetime

Ciao,
io ho creato un servizio che, per semplificare, legge dei dati e li mette in un database. Assieme a questi dati devo aggiungere l'ora di inserimento e finchè provo in locale sul mio pc non ho problemi. Il servizio però deve girare su un server così come il db e ho notato come i formati delle date sia sballati.
Quando utilizzo datetime.now.tostring() invece che visualizzare 1/1/2010 12:00:00 come succedeva sul mio pc, se sposto il servizio sul server mi mostra 1/1/2010 12.00.00 e inserendo la stringa nel db sql mi da errore. Come faccio ad imporre di default la visualizzazione con il separatore ':' ?

Grazie,
ciao
Maxti è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2010, 14:05   #2
Morlack`X
Senior Member
 
L'Avatar di Morlack`X
 
Iscritto dal: Dec 2006
Messaggi: 650
Questo succede perchè probabilmente il tuo pc locale e il database hanno 2 impostazioni di regionalizzazione differenti.

Per esempio l'uso del "." tra le componenti dell'orario sono tipiche della regionalizzazione italiana (it-IT), mentre i ":" di quella americana (en-US).

Per forzare la formattazione con i ":", devi usare il metodo ToString() indicandogli anche la regionalizzazione en-US.

Codice:
using System.Globalization;

...
...

string _time_it = DateTime.Now.ToString("dd/MM/yyyy HH:mm:ss", CultureInfo.CreateSpecificCulture("it-IT")); // Es.: 10/06/2010 14.03.10

string _time_us = DateTime.Now.ToString("dd/MM/yyyy HH:mm:ss", CultureInfo.CreateSpecificCulture("en-US")); // Es.: 10/06/2010 14:03:10
Morlack`X è offline   Rispondi citando il messaggio o parte di esso
Old 11-06-2010, 09:18   #3
Maxti
Member
 
Iscritto dal: Mar 2010
Messaggi: 53
Ok grazie, funziona. Ci sarebbe un modo definitivo per imporre questo tipo di formattazione magari definendo la culture all'inizio in modo che non sia necessario ogni volta che si usa un datetime specificare il formato?
Maxti è offline   Rispondi citando il messaggio o parte di esso
Old 11-06-2010, 09:34   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Maxti Guarda i messaggi
Ok grazie, funziona. Ci sarebbe un modo definitivo per imporre questo tipo di formattazione magari definendo la culture all'inizio in modo che non sia necessario ogni volta che si usa un datetime specificare il formato?
Per quanto riguarda la lingua puoi usare:
Codice:
System.Threading.Thread.CurrentThread.CurrentCulture
Da impostare su ogni thread se l'applicativo è multithread
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 12:27   #5
Maxti
Member
 
Iscritto dal: Mar 2010
Messaggi: 53
Senza aprire un altro topic volevo chiedere un'altra cosa che riguarda il datetime ma in questo caso in sql.
Sul mio pc con sql 2005 la data me la mostra come gg/mm/yyyy, mentre sql 2008 su un server la mostra come yyyy-mm-gg. Ora tutte le volte che devo spostarmi da un sql all'altro devo cambiare la formattazione della data in c#, ma non c'è un modo per specificare definitivamente il formato datetime di una colonna in sql?
grazie
Maxti è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 12:36   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
E perchè mai dovresti formattare le date direttamente sul server?
Usando DateTime (invece delle stringhe) per leggere e scrivere dovresti essere a posto.

Dov'è che ti viene mostrata la data? E' il Management Studio o un tuo applicativo?
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 12:49   #7
Maxti
Member
 
Iscritto dal: Mar 2010
Messaggi: 53
Si non lo avevo specificato ma è management studio. Sostanzialmente in sql 2005 in locale se da c# volevo inserire una voce di tipo datetime gli passavo il datetime.tostring() e non creava problemi, ora su sql 2008 devo specificare il formato che vedo in management studio ovvero yyyy-mm-gg.
Maxti è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 13:01   #8
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Maxti Guarda i messaggi
Si non lo avevo specificato ma è management studio. Sostanzialmente in sql 2005 in locale se da c# volevo inserire una voce di tipo datetime gli passavo il datetime.tostring() e non creava problemi, ora su sql 2008 devo specificare il formato che vedo in management studio ovvero yyyy-mm-gg.
Ma perchè usi le date come stringa?
Non puoi usare direttamente la classe DateTime?
Per caso componi le query concatenando i valori?
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 14:29   #9
Maxti
Member
 
Iscritto dal: Mar 2010
Messaggi: 53
Sostanzialmente faccio delle query del tipo
Codice:
SqlCommand c = new SqlCommand("INSERT INTO abc colonna1 values '"+ tipodatetime+"' ecc...
comunque anche non specificando il toString non cambia nulla
Maxti è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 15:58   #10
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Se non usi gli SqlParameter devi formattare le date nel formato stringa atteso da SqlServer:
Codice:
datetime.ToString("yyyy-MM-dd HH:mm:ss:fff").Replace('.', ':')
tomminno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
AOC propone un QD-OLED al prezzo di un I...
AGCOM segnalerà la AI Mode di Goo...
L'Estonia porta ChatGPT in classe: firma...
2 nm giapponesi contro TSMC: il piano di...
Questa scopa elettrica Tineco iFLOOR 5 è...
FRITZ!Box 6825 4G sbarca in Italia a 129...
Red Hat presenta Digital Sovereignty Rea...
AMD Zen 6 'Olympic Ridge': sette configu...
Amazon batte Walmart dopo 30 anni: il so...
Digos nel mirino dell'intelligence cines...
Sony non vuole aumentare il prezzo della...
Energia geotermica: la (costosa) rispost...
MG ha già venduto 1 milione di au...
"Something Big Is Happening" —...
Renault chiude il 2025 con una perdita r...
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: 20:46.


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