【发布时间】:2018-01-09 23:37:34
【问题描述】:
我正在尝试检索符合我的条件的行数,但我一直返回 0 行..
SQL 查询:
SELECT COUNT(*)
FROM AuditActivity
WHERE Username = '______'
AND DateTimeActivity >= CONVERT(datetime, '01/08/2017 00:00:00')
AND DateTimeActivity <= CONVERT(datetime, '01/08/2017 23:59:59')
AND ActivityType = 'Login'
SQL Server 表中的数据:
检索方法中使用的代码:
// Bar Chart Current Week Monday (Login)
public int barMondayLogin(String username)
{
int result = 0;
StringBuilder sqlCmd = new StringBuilder();
sqlCmd.AppendLine("SELECT COUNT(*) FROM AuditActivity WHERE Username = @getUsername AND DateTimeActivity BETWEEN @getFirstDT AND @getLastDT AND ActivityType = @getType");
try
{
SqlConnection myConn = new SqlConnection(DBConnectionStr);
myConn.Open();
SqlCommand cmd = new SqlCommand(sqlCmd.ToString(), myConn);
//DateTime
DateTime currentDT = DateTime.Today;
DateTime FirstDT = currentDT.AddDays(-(int)currentDT.DayOfWeek + 1);
DateTime SecondDT = FirstDT.AddDays(1).AddSeconds(-1);
Debug.WriteLine("Date: " + FirstDT + " " + SecondDT);
cmd.Parameters.AddWithValue("@getUsername", username);
cmd.Parameters.AddWithValue("@getFirstDT", FirstDT);
cmd.Parameters.AddWithValue("@getLastDT", SecondDT);
cmd.Parameters.AddWithValue("@getType", "Login");
myConn.Close();
return result;
}
catch (SqlException ex)
{
logManager log = new logManager();
log.addLog("AuditNLoggingDAO.barMondayLogin", sqlCmd.ToString(), ex);
return 0;
}
}
会不会是日期时间格式错误?
感谢任何帮助,谢谢!
【问题讨论】:
-
尝试与语言环境无关的格式:'20170801 23:59:59'
-
您能否更新一下您使用哪种方法来检索数据? ExecuteNonQuery 还是 ExecuteScalar?
-
我没有看到
cmd.ExecuteReader();? -
如果解决了,则将响应标记为答案。 不要编辑你的标题说“[已解决]”。