Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Übergeben Sie datetime an die gespeicherte Prozedur

Verwenden Sie DateTime.ParseExact Um Ihre Zeichenfolge in eine Datumszeit umzuwandeln, übergeben Sie die Datumszeit

string test = "2014-09-18";
DateTime dt = DateTime.ParseExact(test, "yyyy-MM-dd", CultureInfo.InvariantCulture);
SqlParams[0] = new SqlParameter("@StartDate", SqlDbType.DateTime);
SqlParams[0].Value = dt;

Wenn Ihre Eingabe von einem vom Benutzer eingegebenen Wert stammt, ist es wahrscheinlich besser, DateTime.TryParseExact um die Eingabe zu überprüfen, ohne eine Ausnahme zu erhalten.

if(!DateTime.TryParseExact(test, "yyyy-MM-dd", 
             CultureInfo.InvariantCulture, DateTimeStyles.None, out dt))
{
    MessageBox.Show("Type a date in the format yyyy-MM-dd");
    return;
}