将varchar数据类型转换为datetime数据类型时出现了超出范围值的错误。
我正在尝试使用表单向我的表中输入数据,表单验证和SQL Server中的日期格式都是dd/mm/yy。但是,当我尝试提交一个大于12的日期(例如13/12/2012)时,它会抛出异常,原因是“将varchar数据类型转换为datetime数据类型时出现了超出范围值的错误”。如果我尝试以mm/dd/yy格式输入数据,则会显示“日期格式错误”,这意味着dd/mm/yy格式是正确的格式。
以下是我的表单代码:
我正在尝试使用表单向我的表中输入数据,表单验证和SQL Server中的日期格式都是dd/mm/yy。但是,当我尝试提交一个大于12的日期(例如13/12/2012)时,它会抛出异常,原因是“将varchar数据类型转换为datetime数据类型时出现了超出范围值的错误”。如果我尝试以mm/dd/yy格式输入数据,则会显示“日期格式错误”,这意味着dd/mm/yy格式是正确的格式。
以下是我的表单代码:
private void btnAddProject_Click(object sender, EventArgs e)
{
DateTime startDate;
DateTime endDate;
if (txtProjectName.Text == "") //client side validation
{
MessageBox.Show("Enter Project Name");
return;
}
try
{
startDate = DateTime.Parse(txtProjectStart.Text);
endDate = DateTime.Parse(txtProjectEnd.Text);
}
catch (Exception)
{
MessageBox.Show("Wrong Date Format");
return;
}
fa.CreateProject(txtProjectName.Text, startDate, endDate, (int)cbCustomers.SelectedValue, ptsUser.Id);
txtProjectName.Text = "";
txtProjectStart.Text = "";
txtProjectEnd.Text = "";
cbCustomers.SelectedIndex = 0;
MessageBox.Show("Project Created");
adminControl.SelectTab(2);
}// end btnAddProject
这是我的DAO中的代码:
public void CreateProject(string name, DateTime startDate, DateTime endDate, int customerId, int administratorId)
{
string sql;
SqlConnection cn;
SqlCommand cmd;
Guid projectId = Guid.NewGuid();
sql = "INSERT INTO Project (ProjectId, Name, ExpectedStartDate, ExpectedEndDate, CustomerId, AdministratorId)";
sql += String.Format("VALUES('{0}', '{1}', '{2}', '{3}', {4}, {5})", projectId, name, startDate, endDate, customerId, administratorId);
cn = new SqlConnection(Properties.Settings.Default.WM75ConnectionString);
cmd = new SqlCommand(sql, cn);
try
{
cn.Open();
cmd.ExecuteNonQuery();
}
catch (SqlException ex)
{
throw new Exception("Error Creating Project", ex);
}
finally
{
cn.Close();
}
}//end CreateProject Method
这是我的Facade代码:
public void CreateProject(string name, DateTime startDate, DateTime endDate, int customerId, int administratorId)
{
dao.CreateProject(name, startDate, endDate, customerId, administratorId);
}//end CreateProject