设为首页 收藏本站
查看: 1263|回复: 0

[经验分享] SqlDependency执行复杂SQL语句

[复制链接]

尚未签到

发表于 2016-11-10 11:15:48 | 显示全部楼层 |阅读模式
  参考:
  l
http://msdn.microsoft.com/en-US/library/3ht3391b(v=vs.80).aspx

  l
http://msdn.microsoft.com/en-us/library/a52dhwx7(v=vs.80).aspx

  l
http://www.codeproject.com/Articles/144344/Query-Notification-using-SqlDependency-and-SqlCach

  l
http://blog.csdn.net/jinjazz/article/details/2739228

  
  SqlDependency监听的SQL语句有很多限制。参考:http://msdn.microsoft.com/en-US/library/ms181122.aspx。
  我有一个需求:用sql1监听table_A,但是需要的结果是sql2(table_A和table_B的outer joinsql语句)
  一直以为只要简单在OnChangeEventHandler托管函数中,不执行sql1,直接执行sql2。但是测试总是不成功。后来尝试了几次才发现:
  SqlDependency启用监听sql1语句后,如果不执行被监听语句sql1,那么就不能执行其他sql语句。
  
  下面是我的代码示例。
  

  在global.asax Application_Start函数和Application_End函数中启用和停止服务的监听。

  

void Application_Start(object sender, EventArgs e)
{
// Code that runs on application startup
SqlDependency.Start(ConfigurationManager.ConnectionStrings["www.cngoldzone.com"].ConnectionString);
}
void Application_End(object sender, EventArgs e)
{
//  Code that runs on application shutdown
SqlDependency.Stop(ConfigurationManager.ConnectionStrings["www.cngoldzone.com"].ConnectionString);
}
  在 default.aspx中添加两个控件:GridView1, lblDate
  对应的defualt.aspx.cs文件代码:

  

public partialclass _Default : System.Web.UI.Page
{
privatestatic DateTime updateTime = DateTime.Now;
protectedvoid Page_Load(object sender, EventArgs e)
{
if(!IsPostBack)
{
if(Cache["TableDate"]==null)
{
GetData();
}
DataTable dt =(DataTable)Cache["TableDate"];
GridView1.DataSource= dt;
GridView1.DataBind();
lblDate.Text= updateTime.ToString();
}
}
privatestring GetListenSQL()
{
return sql1
}
privatestring GetSelectSQL()
{
return sql2;
}
privatevoid GetSelectData()
{
using(SqlConnection cn =new SqlConnection(ConfigurationManager.ConnectionStrings["www.cngoldzone.com"].ConnectionString))
{
using(SqlCommand cmd = cn.CreateCommand())
{
cn.Open();
cmd.CommandText= GetSelectSQL();
DataTable dt =new DataTable();
using(SqlDataReader rdr= cmd.ExecuteReader())
{
dt.Load(rdr);
}
Cache["TableDate"]= dt;
updateTime = DateTime.Now;
}
}
}
privatevoid GetData()
{
using(SqlConnection cn =new SqlConnection(ConfigurationManager.ConnectionStrings["www.cngoldzone.com"].ConnectionString))
{
using(SqlCommand cmd = cn.CreateCommand())
{
cn.Open();
cmd.CommandText= GetListenSQL();
SqlDependency dep=new SqlDependency(cmd);
//当有DML操作时,onChange事件会接收来自Sql Server通过sq_DispatcherProc存储过程发送给应用程序的消息。
dep.OnChange+=new OnChangeEventHandler(dep_OnChange);
DataTable dt =new DataTable();
cmd.ExecuteScalar();
}
}
GetSelectData();
}
void dep_OnChange(object sender, SqlNotificationEventArgs e)
{
/*
当取数据时间长时,有可能数据未取完,窗口就初关闭.所以先删除Cahce,在取数据。
*/
Cache.Remove("Cache");
GetData();
}
}
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-298412-1-1.html 上篇帖子: DB2 SQL语句笔记 下篇帖子: SQL锁的概述
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表