一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

.NET遠(yuǎn)程處理框架詳解

  第1章系統(tǒng)總體結(jié)構(gòu)

  1.1 總體結(jié)構(gòu)

  系統(tǒng)實(shí)現(xiàn)需要部署服務(wù)器端的遠(yuǎn)程對(duì)象(即一個(gè)DbServerLibrary.dll),服務(wù)器端要注冊(cè)通道和該遠(yuǎn)程對(duì)象。客戶端要實(shí)現(xiàn)一個(gè)本地查詢的服務(wù)器,同時(shí)根據(jù)SQL解析的結(jié)果向各個(gè)服務(wù)器發(fā)送命令,并將結(jié)果顯示在客戶端界面,服務(wù)器端可以接受并顯示相應(yīng)的命令。

  1.2 關(guān)鍵組件結(jié)構(gòu)

  系統(tǒng)結(jié)構(gòu)中關(guān)鍵的組件有遠(yuǎn)程對(duì)象,和本地服務(wù)器,實(shí)現(xiàn)的功能基本一致。下面以遠(yuǎn)程對(duì)象為例,說明組件的實(shí)現(xiàn)。遠(yuǎn)程對(duì)象在服務(wù)器端解決方案下的庫(kù)文件中聲明,通過服務(wù)器端進(jìn)行注冊(cè),客戶端通過TCP通道與服務(wù)器端遠(yuǎn)程對(duì)象通信,實(shí)現(xiàn)數(shù)據(jù)集的查詢和傳輸。主要的數(shù)據(jù)成員有:SqlConnection(SQL Server數(shù)據(jù)庫(kù)的連接對(duì)象)、 SqlCommand (SQL命令對(duì)象)、SqlDataAdapter(數(shù)據(jù)適配器,填充數(shù)據(jù)集)組件——DbServerLibrary。

  第2 章.NET遠(yuǎn)程處理框架提供的強(qiáng)大技術(shù)

  因時(shí)間倉(cāng)促,未實(shí)現(xiàn)數(shù)據(jù)字典,所有實(shí)驗(yàn)要求的SQL經(jīng)過解析后,直接通過代碼判斷,向相應(yīng)場(chǎng)地發(fā)送命令。

  代碼分為三部分:遠(yuǎn)程對(duì)象,服務(wù)器端代碼和客戶端代碼。

  其中:遠(yuǎn)程對(duì)象部署在各個(gè)服務(wù)器端,客戶端除了實(shí)現(xiàn)查詢命令的解析和傳送外外,還有一個(gè)本地服務(wù)器,進(jìn)行相應(yīng)的本地查詢。

遠(yuǎn)程對(duì)象代碼:

   1. usingSystem;  
2. usingSystem.Runtime.Serialization;
3. usingSystem.Data;
4. usingSystem.Data.SqlClient;
5. usingSystem.Windows.Forms;
6. namespaceDbServerLibrary{
7. [SerializableAttribute]//ItisveryimportantforRemotingData
8. publicclassDbServer:MarshalByRefObject{
9. privatestringconnStr;
10. privatestringclientSql;
11. publicSqlConnectionsqlConn;
12. publicSqlCommandsqlComm;
13. publicSqlDataAdaptersqlAdapter;
14. publicvoidGetClientSql(stringsql){
15. if(clientSql!=null){
16. clientSql=null;
17. }
18. clientSql=sql;
19. MessageBox.Show(clientSql);
20. }
21. publicDbServer(){
22. //LocalDataInitialize
23. cnnStr="DataSource=localhost;InitialCatalog=DDB;UserID=sa;Password=;";
24. sqlConn=newSqlConnection(connStr);
25. }
26. publicDataSetGetDataSet()
27. //執(zhí)行select
28. DataSetds=newDataSet();
29. if(sqlComm!=null){
30. sqlComm=null;
31. }
32. if(sqlConn.State==ConnectionState.Closed){
33. sqlConn.Open();
34. }
35. try{
36. sqlComm=newSqlCommand();
37. sqlComm.Connection=sqlConn;
38. sqlComm.CommandText=clientSql;
39. sqlComm.CommandType=CommandType.Text;
40. sqlAdapter=newSqlDataAdapter();
41. sqlAdapter.SelectCommand=sqlComm;
42. sqlAdapter.Fill(ds);
43. }
44. catch(SqlExceptionex){
45. MessageBox.Show(ex.Message);
46. }
47. returnds;
48. }
49. publicintExecuteSql()//執(zhí)行insert和delete{
50. intaffectedNumber;
51. if(sqlComm!=null){
52. sqlComm=null;
53. }
54. if(sqlConn.State==ConnectionState.Closed){
55. sqlConn.Open();
56. }
57. try{
58. sqlComm=newSqlCommand();
59. sqlComm.Connection=sqlConn;
60. sqlComm.CommandType=CommandType.Text;
61. sqlComm.CommandText=clientSql;
62. affectedNumber=sqlComm.ExecuteNonQuery();
63. returnaffectedNumber;
64. }
65. catch(SqlExceptionex){
66. MessageBox.Show(ex.Message);
67. return0;
68. }
69. }
70. }
71. }

NET技術(shù).NET遠(yuǎn)程處理框架詳解,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美激情 亚洲 | 久久逼逼| 国产第一第二第三第四第五 | 亚洲第一区精品日韩在线播放 | 亚洲精品人成网在线播放影院 | 91久久免费视频 | 色老板成人永久免费视频 | 日韩久久久精品中文字幕 | 玖玖爱视频在线 | 久久91精品国产91久久跳舞 | 日本护士xxxxx18.19 | 国产精品自在自线亚洲 | 一区二区三区四区精品视频 | 亚洲第一页视频 | 91福利在线观看视频 | 人人爰人人人人人鲁 | 国产成人精品自线拍 | 国产精品综合在线 | 国产拍在线 | 亚洲精品www久久久久久 | 久久综合免费视频 | 国产女同一区二区三区五区 | 欧美日韩亚洲精品国产色 | 国产精品久久久久影院色老大 | 欧美xxxx另类 | 在线五月婷婷 | www国产精品com | 日本一区二区三区在线 视频观看免费 | 日本一区二区视频免费播放 | 国产九色 | 99久久精品免费看国产高清 | 久久99爰这里有精品国产 | 日本在线观看永久免费网站 | 国内真实愉拍系列情侣自拍 | 久久国产乱子伦精品在 | 黄色片视频免费 | 韩国免费特一级毛片 | 色加勒比| 国产色拍 | 亚洲国产精品自产在线播放 | 九月婷婷亚洲综合在线 |