我的表 TimeTable 中有 2 列
start_date
(格式为DD-MM-YYYY
)end_date
如果我从我的登录页面登录,我想检查当前日期是否在start_date
和之间end_date
;如果是这样,我可以登录。
如何在 C#..asp.net.. 中进行比较?
我已成功在登录页面中打印当前日期。
lblMsg.Text= DateTime.Now.ToString("dd-MM-yyyy");
我在 c# 中使用 asp.net
start_date end_date
8/2/2013 12:00:00 AM 10/2/2013 12:00:00 AM
以 DD/MM/YYYY 格式存储日期的代码
CultureInfo 提供者 = CultureInfo.InvariantCulture;
DateTime startdate = DateTime.ParseExact(tbstartdate.Text.ToString().Trim(), "dd/MM/yyyy", provider);
DateTime enddate = DateTime.ParseExact(tbenddate.Text.ToString().Trim(),"dd/MM/yyyy",provider);
string sql = "INSERT INTO TimeTable(start_date,end_date)"
+ "VALUES (@startdate,@enddate)";
SqlConnection conn = new SqlConnection(ConnectionString);
conn.Open();
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.Add("@startdate", SqlDbType.DateTime).Value = startdate;
cmd.Parameters.Add("@enddate", SqlDbType.DateTime).Value = enddate;
cmd.Prepare();
n = cmd.ExecuteNonQuery();
conn.Close();
登录页面查看日期代码
CultureInfo 提供者 = CultureInfo.InvariantCulture;
DateTime date = DateTime.ParseExact(DateTime.Now.ToString("dd/mm/yyyy"), "dd/MM/yyyy", provider);
// DateTime date=DateTime.Now.ToString("dd/mm/yyyy");
string query1 = "select * from TimeTable where ((start_date >= @date1 and End_date<= @date2) and UserType=@type)";
SqlConnection conn = new SqlConnection(ConnectionString);
conn.Open();
SqlCommand com = new SqlCommand(query1, conn);
com.Parameters.Add("@type",dpusertype.SelectedItem.Text.ToString());
com.Parameters.Add("@date1",date);
com.Parameters.Add("@date2", date);
com.CommandType = CommandType.Text;
SqlDataAdapter da = new SqlDataAdapter(com);
DataTable dt = new DataTable();
da.Fill(dt);
`if (dt.Rows.Count > 0) // 比较表中的用户
{
FormsAuthentication.RedirectFromLoginPage(txtFcode.Text, Persist.Checked);
Response.Redirect("~/DeptCoordinator/DeptCoordinator_homepage.aspx");
}
出现错误
日历 System.Globalization.GregorianCalendar 不支持字符串表示的 DateTime。描述`