欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

sqldependency類輪詢功能

系統(tǒng) 1668 0

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

1、創(chuàng)建sql測(cè)試環(huán)境

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下用一個(gè)form和datagridview來測(cè)試

C# code
using System; using System.Data; using System.Windows.Forms; using System.Data.SqlClient; namespace WindowsApplication10 { public partial class Form1 : Form { // 拖一個(gè)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); // 啟動(dòng) GetData(); // 獲取數(shù)據(jù) } private void GetData() { command.Notification = null ; // 清除 SqlDependency dependency = new SqlDependency(command); // 設(shè)置通知 dependency.OnChange += new OnChangeEventHandler(sqlDependency_OnChange); // 通知事件 using (SqlDataAdapter adapter = new SqlDataAdapter(command)) // 查詢數(shù)據(jù) { System.Data.DataSet ds = new DataSet(); adapter.Fill(ds, 0 , 3 , " test " ); dataGridView1.DataSource = ds.Tables[ " test " ]; } } void sqlDependency_OnChange( object sender, SqlNotificationEventArgs e) { // 因?yàn)槭亲泳€程,需要用invoke方法更新ui if ( this .InvokeRequired) { this .Invoke( new OnChangeEventHandler(sqlDependency_OnChange), new object [] { sender, e }); } else { SqlDependency dependency = (SqlDependency)sender; dependency.OnChange -= sqlDependency_OnChange; // 通知之后,當(dāng)前dependency失效,需要重新getdata并且設(shè)置通知 GetData(); } } private void Form1_FormClosed( object sender, FormClosedEventArgs e) { // 清理現(xiàn)場(chǎng) SqlDependency.Stop(connString); conn.Close(); conn.Dispose(); } } }


3、啟動(dòng).net程序,表格中會(huì)有3條記錄,然后切換到數(shù)據(jù)庫中,繼續(xù)插入一些數(shù)據(jù)

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



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


關(guān)于SqlDependency類,很多人無法測(cè)試成功,因?yàn)樗南拗坪芏啵δ芸赡苡写訌?qiáng),稍微不注意就會(huì)讓上面的代碼陷入死循環(huán)。特別要注意的就是command的sql語句問題:

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

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

sqldependency類輪詢功能


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

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

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 爱豆在线观看网址91 | 免费 | 色综合天天综合中文网 | 亚洲国产七七久久桃花 | 福利免费在线 | 欧美18videos性处按摩 | 免费看黄网站在线 | 一级片一级片一级片一级片 | 91中文字幕在线 | 亚洲国产路线1路线2路线 | 欧美一区二区三区久久精品 | 五月天婷婷综合 | 精品伊人网 | 黄色一级片视频 | 日韩欧美视频在线一区二区 | 午夜深夜福利网址 | 日韩资源在线 | 毛片免费观看视频 | 欧美视频免费 | 成人18免费网站在线观看 | 国产精品第9页 | 高清国语自产拍免费视频国产 | 国产精品点击进入在线影院高清 | 久久久久亚洲一区二区三区 | 91久久国产视频 | 99精品久久秒播无毒不卡 | 九月色婷婷 | 涩涩屋av | 亚洲欧美综合日韩字幕v在线 | 中文字幕日韩理论在线 | 日韩h片在线观看 | 欧美性猛交xxxx乱大交蜜桃 | 香蕉国产成版人视频在线观看 | 91亚洲精品在线观看 | 美女扣下面流白浆丝袜 | 国产合集福利视频在线视频 | 波多野吉衣一区二区 | 国产成人+综合亚洲+天堂 | 全部免费国产潢色一级 | 国产毛片片精品天天看视频 | 黄色a一级视频 | 91插视频 |