【发布时间】:2011-11-23 03:43:40
【问题描述】:
我遇到了问题,我正在尝试从消息表中获取更新以进行网络聊天。为此,我将最后一个日期时间存储在会话中,并尝试获取在最后一个日期时间和现在之间发送的消息。
但是,它缺少一些消息,我不知道为什么。我的 mysql 日期时间比较有问题吗?
如果我刷新页面,它会重置会话变量并显示所有消息。在 javascript 中,我每 2 + 回调秒调用一次 web 方法。
private string LastNow
{
get
{
return Session["last_now"] as string ??
(string)(Session["last_now"] = string.Empty);
}
set
{
Session["last_now"] = value;
}
}
[WebMethod(EnableSession=true)]
public object GetMessages(int id, int roomId)
{
string lastDt = LastNow;
/* EDIT */
string now = MySqlHelper.ExecuteScalar(
connstr, "SELECT CAST(NOW() AS CHAR);") as string;
// if the session variable is null or empty,
// get all messages up to now, else most recent
string dtclause =
!string.IsNullOrWhiteSpace(lastDt) ?
string.Format(" AND sent_dt > '{0}' AND sent_dt <= '{1}'", lastDt, now) :
string.Format(" AND sent_dt <= '{0}'", now);
string sql =
string.Format(
"SELECT user_id, type, message FROM Chat.Message WHERE room_id={0}{1};",
roomId, dtclause);
object ret = null;
try // with a finally, always store last update time
{
using (DataSet msgset =
MySqlHelper.ExecuteDataset(Common.SupportDatabase, sql))
{
DataTable msgtable = msgset.Tables[0];
if (msgtable != null)
{
DataRow[] rows = msgtable.Select();
if (rows != null && rows.Length > 0)
{
ret = from msg in rows
select new
{
id = msg["user_id"],
type = msg["type"],
message = msg["message"]
};
}
}
}
}
finally
{
LastNow = now;
}
return ret;
}
【问题讨论】:
标签: c# mysql web-services select where-clause