Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Peugeot Polygon Concept: ecco il futuro delle utilitarie
Peugeot Polygon Concept: ecco il futuro delle utilitarie
Polygon è la concept car di Peugeot che mostra il futuro delle soluzioni del segmento B: tra design compatti e innovativi affiancati da dimensioni compatte uno scherzo dalla manovrabilità incredibile per le manovre a bassa velocità
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-06-2010, 11: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, 13: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, 08: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, 08: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, 11: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, 11: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, 11: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, 12: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, 13: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, 14: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


Peugeot Polygon Concept: ecco il futuro delle utilitarie Peugeot Polygon Concept: ecco il futuro delle ut...
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 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 ...
Redmi Note 17 a un passo dal debutto, ma...
Gli aumenti di prezzo del PS Plus potreb...
Almeno 64 GB di RAM per giocare? Il caso...
Gemini si integrerà con le auto e potrà ...
Addio a OxygenOS di OnePlus e alla Realm...
Intel conferma l'aumento dei prezzi su C...
In vendita Withings BodyFit, molto più d...
Inkterface: Steam Machine ospita un pann...
Stare seduti oltre 30 minuti di fila aum...
A Milano l'Italia ha firmato la sovranit...
Cos'è PeerTube, la piattaforma di...
In 12 articoli TOP c'è il meglio ...
La pirateria è l'unica tutela per...
Roomba Plus 516 Combo in offerta a 479€:...
ASUS ROG Strix G16 con RTX 5070 Ti super...
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:48.


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