c#-SqlDependency.OnChange没有在datetime列上使用过滤器触发
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c#-SqlDependency.OnChange没有在datetime列上使用过滤器触发,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2292字,纯文字阅读大概需要4分钟。
内容图文
我在SqlDependency中使用此SQL语句时遇到问题.它只是不激活SqlDependency.OnChange事件,而是在SQL Server查询窗口中按预期返回结果.
SELECT [Order].OrderId
FROM [dbo].[Order]
WHERE [Order].CreatedOn > '20150815 21:11:57.502'
我在这里阅读了支持的SELECT语句部分https://technet.microsoft.com/en-us/library/ms181122(v=sql.105).aspx,但没有发现任何违反的规则.
有任何想法吗?
更新:
我的完整代码如下:
private void CheckForNewOrders(DateTime dt)
{
string json = null;
string conStr = ConfigurationManager.ConnectionStrings["connstring"].ConnectionString;
using (SqlConnection connection = new SqlConnection(conStr))
{
string query = string.Format(@"
SELECT [Order].OrderId
FROM [dbo].[Order]
WHERE [Order].CreatedOn > '{0}'"
, dt.ToString("yyyyMMdd HH:mm:ss.fff")); // 20150814 00:00:00.000
using (SqlCommand command = new SqlCommand(query, connection))
{
command.Notification = null;
SqlDependency dependency = new SqlDependency(command);
dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
connection.Open();
SqlDataReader reader = command.ExecuteReader();
if (reader.HasRows)
{
reader.Read();
json = "testing ... "; reader[0].ToString();
}
}
}
}
private void dependency_OnChange(object sender, SqlNotificationEventArgs e)
{
if (e.Type == SqlNotificationType.Change)
{
CheckForNewOrders(DateTime.Now);
}
}
更新(响应jmelosegui的回答):
query = string.Format(@"
SELECT [Order].OrderId
FROM [dbo].[Order]
WHERE [Order].CreatedOn > @CreatedOn");
…
using (SqlCommand command = new SqlCommand(query, connection))
{
command.Parameters.Add("@CreatedOn", SqlDbType.DateTime);
command.Parameters["@CreatedOn"].Value = DateTime.Now;
command.Notification = null;
SqlDependency dependency = new SqlDependency(command);
dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
connection.Open();
SqlDataReader reader = command.ExecuteReader();
if (reader.HasRows)
{
...
}
}
解决方法:
我认为您应该只获得通知事件,而不是那种类型.
您能否在else_OnChange方法中添加一个else分支,以查看是否正在获取其他任何SqlNotificationType,例如:
private void dependency_OnChange(object sender, SqlNotificationEventArgs e)
{
if (e.Type == SqlNotificationType.Change)
{
CheckForNewOrders(DateTime.Now);
}
else
{
//Do somthing here
Console.WriteLine(e.Type);
}
}
更新资料
您能否尝试添加类型化参数:
WHERE [Order].CreatedOn > @myDateTime
并传入DateTime类型的参数,而不使用字符串转换.
内容总结
以上是互联网集市为您收集整理的c#-SqlDependency.OnChange没有在datetime列上使用过滤器触发全部内容,希望文章能够帮你解决c#-SqlDependency.OnChange没有在datetime列上使用过滤器触发所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。