書式設定された日時変数を SQL Server に渡す作業を行っています。日付は 2 つの異なるコントロールに由来するため、日付と時刻を連結する必要があります。コードは正常に動作しているようで、2 つの文字列が結合されると、DateTime として解析されます。
問題は、SQL Server に移行すると、時刻の部分が失われ、列が(たとえば) とは対照的に表示yyyy-mm-dd hh:mm:ss.fff
されることです。2012-09-03 00:00:00.000
2012-09-03-12 1:23:45:678
これが私のコードです。テストのために、時間をハードコードされobjInfo.SemesterEnrollStart
た変数に置き換えました。これはDateTime
変数です。また、コントロールdpEnrollStart
はDatePicker
.
DateTime semDate = Convert.ToDateTime(dpEnrollStart.SelectedDate);
string semTime = "12:34";
DateTime dtp = DateTime.ParseExact(semDate.ToShortDateString() + " " + semTime, "MM/dd/yyyy hh:mm", null);
objInfo.SemesterEnrollStart = dtp;
本当にありがとう!
編集:だから、ストアド プロシージャを呼び出すために使用している c# は次のとおりです。
objInfo.SemesterQuarter = ddl_SemQuarter.SelectedValue;
objInfo.SemesterYear = ddl_SemYear.SelectedValue;
objInfo.SemesterStart = Convert.ToDateTime(dpSemStart.SelectedDate);
objInfo.SemesterEnd = Convert.ToDateTime(dpSemEnd.SelectedDate);
DateTime semDate = Convert.ToDateTime(dpEnrollStart.SelectedDate);
string semTime = "12:34:00.000";
objInfo.SemesterEnrollStart = DateTime.ParseExact(semDate.ToShortDateString() + " " + semTime, "MM/dd/yyyy HH:mm:ss.fff", null);
objInfo.SemesterEnrollEnd = Convert.ToDateTime(dpEnrollEnd.SelectedDate);
objInfo.PriorityRegDate = Convert.ToDateTime(dpPriRegDate.SelectedDate);
objInfo.AgeCutoffDate = Convert.ToDateTime(dpAgeCutoffDate.SelectedDate);
lblTSMessage.Text = objInfo.SemesterEnrollStart.ToString();
objManager.AddNewSemester(objInfo);