亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

sqldependency類輪詢功能

系統 1601 0

System.Data.SqlClient.SqlDependency類為我們提供了一個關于sql2005的很好的功能 ,雖然這個東西限制有很多很多,但還是有很實用價值的。
我們先看一個演示例子:
例子中先創建一個sql環境,里面插入了一些數據,然后用.net客戶端查詢,查詢結果出來后再去更改數據庫,增加一些記錄,同時查看.net客戶端的表格是否變化。

1、創建sql測試環境

SQL code
use master go create database dbTest go use dbTest go create table test(id int identity ( 1 , 1 ),name varchar ( 10 )) insert into test(name) select ' aa ' insert into test(name) select ' bb ' insert into test(name) select ' cc ' insert into test(name) select ' dd ' insert into test(name) select ' ee ' go alter database dbTest set enable_broker


2、在windows下用一個form和datagridview來測試

C# code
using System; using System.Data; using System.Windows.Forms; using System.Data.SqlClient; namespace WindowsApplication10 { public partial class Form1 : Form { // 拖一個DataGridView到Form中 public Form1() { InitializeComponent(); } // 變量 string connString = " server=localhost;uid=sa;pwd=sqlgis;database=dbTest " ; System.Data.SqlClient.SqlConnection conn = null ; System.Data.SqlClient.SqlCommand command = null ; // 出示化 private void Form1_Load( object sender, EventArgs e) { conn = new System.Data.SqlClient.SqlConnection(connString); command = conn.CreateCommand(); command.CommandText = " select id,name from dbo.test where id<>4 order by id desc " ; SqlDependency.Start(connString); // 啟動 GetData(); // 獲取數據 } private void GetData() { command.Notification = null ; // 清除 SqlDependency dependency = new SqlDependency(command); // 設置通知 dependency.OnChange += new OnChangeEventHandler(sqlDependency_OnChange); // 通知事件 using (SqlDataAdapter adapter = new SqlDataAdapter(command)) // 查詢數據 { System.Data.DataSet ds = new DataSet(); adapter.Fill(ds, 0 , 3 , " test " ); dataGridView1.DataSource = ds.Tables[ " test " ]; } } void sqlDependency_OnChange( object sender, SqlNotificationEventArgs e) { // 因為是子線程,需要用invoke方法更新ui if ( this .InvokeRequired) { this .Invoke( new OnChangeEventHandler(sqlDependency_OnChange), new object [] { sender, e }); } else { SqlDependency dependency = (SqlDependency)sender; dependency.OnChange -= sqlDependency_OnChange; // 通知之后,當前dependency失效,需要重新getdata并且設置通知 GetData(); } } private void Form1_FormClosed( object sender, FormClosedEventArgs e) { // 清理現場 SqlDependency.Stop(connString); conn.Close(); conn.Dispose(); } } }


3、啟動.net程序,表格中會有3條記錄,然后切換到數據庫中,繼續插入一些數據

SQL code
insert into test(name) select ' ff ' insert into test(name) select ' gg '



4、切換回.net客戶端,看看表格是否改變


關于SqlDependency類,很多人無法測試成功,因為它的限制很多,功能可能有待加強,稍微不注意就會讓上面的代碼陷入死循環。特別要注意的就是command的sql語句問題:

select id,name from dbo. test where id <>4 order by id desc

很遺憾,他只能支持上面這樣的簡單語句
列 明必須寫,不能用*,不能用top,不能用函數,包括聚合函數,不能用子查詢,包括where后的子查詢,不能用外連接,自連接,不能用臨時表,不能用變 量,不能用視圖,不能垮庫,而且表名之前必須加類似dbo這樣的前綴....具體有多少限制,基本上除了上述的格式或者比上述更簡單的格式,其他的都不可 以。

sqldependency類輪詢功能


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日韩一区二区中文字幕 | 久久性生活片 | 天天做天天爽爽快快 | 亚洲欧美一区二区三区 | 欧美伦理一区二区三区 | 亚洲欧美人成人让影院 | ww亚洲ww在线观看国产 | 国产夜夜操 | 一级女性全黄生活片免费看 | 国产波波社区精品视频 | 久久er热这里只有精品免费 | 伊人天天干 | 欧美天天| 曰本还a大片免费无播放器 曰本黄色录像 | 2018久久久国产精品 | 亚洲成人第一 | 久久精品国产亚洲欧美 | 99爱视频在线观看 | 成人乱色短篇合集 | 天天射日日射 | 久久影院在线 | 国产精品久久久久9999 | 亚洲一区在线视频观看 | 桃色视频网| 成人国产亚洲欧美成人综合网 | 国产精品久久久香蕉 | 日本高清专区一区二无线 | 亚洲大片免费观看 | 国产精品a v 免费视频 | 国产精品一区二区三 | 四虎永久免费观看紧急入口 | 一级毛片 在线播放 | 四虎国产精品永久在线看 | 国产精品免费视频能看 | 亚洲天堂一区在线 | 欧美乱插 | 日本不卡视频免费 | 一级女性全黄生活片看看 | 思思久热re6这里有精品 | 色狠狠一区 | 男人的天堂视频 |