TCPIP傳送協議

以下代碼實現在客戶端查詢成績(數據庫在服務器端):

?客戶端:

???????static void Main(string[] args)
??????? {
??????????? string str = null;
??????????? while (str != Convert.ToString(0))
??????????? {
??????????????? Console.WriteLine("輸入你要查詢的課程名稱:");
??????????????? str = Console.ReadLine();
??????????????? send(str);
??????????? }

??????????? Console.Read();
??????? }
??????? private static void send(string sendstr)
??????? {
??????????? TcpClient client = new TcpClient("127.0.0.1", 5000);
??????????? NetworkStream ns = client.GetStream();
??????????? byte[] btsend = Encoding.UTF8.GetBytes(sendstr);
??????????? try
??????????? {
??????????????? ns.Write(btsend, 0, btsend.Length);
??????????? }
??????????? catch (SocketException sex)
??????????? {
??????????????? Console.WriteLine(sex.Message);
??????????? }

??????????? byte[] btrec = new byte[50];
??????????? ns.Read(btrec, 0, btrec.Length);
??????????? string recstr = Encoding.UTF8.GetString(btrec);
??????????? Console.WriteLine(DateTime.Now.ToShortTimeString() + "/nServer: " + recstr);
??????????? ns.Close();
??????????? client.Close();
??????? }

?

服務器端:

????????private static SqlConnection con = new SqlConnection("server=LISHIC;uid=sa;pwd=;database=exceltosql");
??????? private static SqlCommand cmd = new SqlCommand();
??????? static void Main(string[] args)
??????? {
??????????? IPAddress ipc = IPAddress.Parse("127.0.0.1");
??????????? TcpListener listener = new TcpListener(ipc, 5000);
??????????? listener.Start();

??????????? while (true)
??????????? {
??????????????? TcpClient tc = listener.AcceptTcpClient();
??????????????? NetworkStream ns = tc.GetStream();
??????????????? byte[] btfromc = new byte[100];
??????????????? ns.Read(btfromc, 0, btfromc.Length);
??????????????? string strfromc = Encoding.UTF8.GetString(btfromc);
??????????????? Console.WriteLine(DateTime.Now.ToShortTimeString() + "/nClient: " + strfromc);
??????????????? byte[] btback = Encoding.UTF8.GetBytes(getgrade(strfromc));
??????????????? ns.Write(btback, 0, btback.Length);
??????????????? ns.Close();
??????????????? tc.Close();
??????????? }
??????? }
??????? private static string getgrade(string str)
??????? {
??????????? string strreturn = null;
??????????? cmd.Connection = con;
??????????? cmd.CommandText = "select * from grade where courses like '" + str + "'" ;
??????????? con.Open();
??????????? SqlDataReader reader = cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
??????????? if (reader.Read())
??????????? {
??????????????? strreturn = "課程名稱: " + reader.GetString(1) + "/n學分: " + reader["credit"].ToString() + "/n成績: " + reader.GetInt32(5);
??????????? }
??????????? else
??????????? {
??????????????? strreturn = "沒有符合要求的科目";
??????????? }
??????????? con.Close();
??????????? return strreturn;

??????? }

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/389053.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/389053.shtml
英文地址,請注明出處:http://en.pswp.cn/news/389053.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

sql優化技巧_使用這些查詢優化技巧成為SQL向導

sql優化技巧成為SQL向導! (Become an SQL Wizard!) It turns out storing data by rows and columns is convenient in a lot of situations, so relational databases have remained a cornerstone of data management in businesses across the globe. Structured…

Day 4:集合——迭代器與List接口

Collection-迭代方法 1、toArray() 返回Object類型數據,接收也需要Object對象! Object[] toArray(); Collection c new ArrayList(); Object[] arr c.toArray(); 2、iterator() Collection的方法,返回實現Iterator接口的對象,…

oem是代工還是貼牌_代加工和貼牌加工的區別是什么

展開全部代加工就是替別人加工,貼別人的牌子。貼牌加工即商家自己不生產,而是委托其他生產企e68a8462616964757a686964616f31333365663431業生產,而品牌是自己的。拓展資料:OEM(Original Equipment Manufacture)的基本含義是定牌生…

KNN 算法--圖像分類算法

KNN 算法–圖像分類算法 找到最近的K個鄰居,在前k個最近樣本中選擇最近的占比最高的類別作為預測類別。 給定測試對象,計算它與訓練集中每個對象的距離。圈定距離最近的k個訓練對象,作為測試對象的鄰居。根據這k個緊鄰對象所屬的類別&#xf…

java核心技術-NIO

1、reactor(反應器)模式 使用單線程模擬多線程,提高資源利用率和程序的效率,增加系統吞吐量。下面例子比較形象的說明了什么是反應器模式: 一個老板經營一個飯店, 傳統模式 - 來一個客人安排一個服務員招呼…

物種分布模型_減少物種分布建模中的空間自相關

物種分布模型Species distribution models (SDM; for review and definition see, e.g., Peterson et al., 2011) are a dominant paradigm to quantify the relationship between environmental dynamics and several manifestations of species biogeography. These statisti…

BZOJ1014: [JSOI2008]火星人prefix

BZOJ1014: [JSOI2008]火星人prefix Description 火星人最近研究了一種操作:求一個字串兩個后綴的公共前綴。 比方說,有這樣一個字符串:madamimadam,我們將這個字符串的各個字符予以標號: 序號: 1 2 3 4 5 6…

redis將散裂中某個值自增_這些Redis命令你都掌握了沒?

本章主要內容字符串命令、列表命令和集合命令散列命令和有序集合命令發布命令與訂閱命令其他命令本章將介紹一些沒有在第1章和第2章出現過的Redis命令,學習這些命令有助于讀者在已有示例的基礎上構建更為復雜的程序,并學會如何更好地去解決自己遇到的問題…

asp.net的MessageBox

public class MessageBox{ public enum MsgButton { /// <summary> /// 只是OK按鈕 /// </summary> OK 1, /// <summary> /// 提示是否確定 /// </summary> OKCancel 2 } publ…

深入理解激活函數

為什么需要非線性激活函數&#xff1f; 說起神經網絡肯定會降到神經函數&#xff0c;看了很多資料&#xff0c;也許你對激活函數這個名詞會感覺很困惑&#xff0c; 它為什么叫激活函數&#xff1f;它有什么作用呢&#xff1f; 看了很多書籍上的講解說會讓神經網絡變成很豐富的…

如何一鍵部署項目、代碼自動更新

為什么80%的碼農都做不了架構師&#xff1f;>>> 摘要&#xff1a;my-deploy:由nodejs寫的一個自動更新工具,理論支持所有語言(php、java、c#)的項目,支持所有git倉庫(bitbucket、github等)。github效果如何?如果你的后端項目放在github、bitbucket等git倉庫中管理…

Kettle7.1在window啟動報錯

實驗環境&#xff1a; window10 x64 kettle7.1 pdi-ce-7.1.0.0-12.zip 錯誤現象&#xff1a; a java exception has occurred 問題解決&#xff1a; 運行調試工具 data-integration\SpoonDebug.bat //調試錯誤的&#xff0c;根據錯誤明確知道為何啟動不了&#xff0c;Y--Y-…

opa847方波放大電路_電子管放大電路當中陰極電阻的作用和選擇

膽機制作知識視頻&#xff1a;6P14單端膽機用示波器方波測試輸出波形詳細步驟演示完整版自制膽機試聽視頻&#xff1a;膽機播放《猛士的士高》經典舞曲 熟悉的旋律震撼的效果首先看下面這一張300B電子管電路圖&#xff1a;300B單端膽機原理圖圖紙里面畫圓圈的電阻就是放大電路當…

鍵盤鉤子

C#鍵盤鉤子//*************************鍵盤鉤子********************** //定義變量 public delegate int HookProc(int nCode, Int32 wParam, IntPtr lParam); static int hKeyboardHook 0; HookProc KeyboardHookProcedure; /************************* * 聲明API函數 * ***…

matplotlib基礎函數函數 plot, figure

matplotlib.pyplot.plot(*args, scalexTrue, scaleyTrue,dataNone,**kwargs) 用線段和標記去繪制x和y。調用簽名&#xff1a; plot([x], y, [fmt], *, dataNone, **kwargs) plot([x], y, [fmt], [x2], y2, [fmt2], ..., **kwargs)點或線的坐標由x, y給出 操作參數 fmt 是為了…

清潔數據ploy n_清潔屋數據

清潔數據ploy nAs a bootcamp project, I was asked to analyze data about the sale prices of houses in King County, Washington, in 2014 and 2015. The dataset is well known to students of data science because it lends itself to linear regression modeling. You …

redis安裝redis集群

NoSql數據庫之Redis1、什么是nosql&#xff0c;nosql的應用場景2、Nonsql數據庫的類型a) Key-valueb) 文檔型&#xff08;類似于json&#xff09;c) 列式存儲d) 圖式3、redis的相關概念kv型的。4、Redis的安裝及部署5、Redis的使用方法及數據類型a) Redis啟動及關閉b) Redis的數…

聯想拯救者y7000p加內存條_內存、硬盤不夠用?手把手教你升級聯想拯救者Y7000P...

由于這兩年內存價格的高企&#xff0c;主流筆記本的內存容量被鎖定在 8GB 已經有了相當長的時間。作為近幾個月最熱門的游戲本產品&#xff0c;聯想拯救者 Y7000P 除頂配之外同樣使用的是 8GB 內存和 512GB 固態硬盤的配置。所以買到這款機器的玩家多數都會選擇進行內存和硬盤的…

機器學習實踐一 logistic regression regularize

Logistic regression 數據內容&#xff1a; 兩個參數 x1 x2 y值 0 或 1 Potting def read_file(file):data pd.read_csv(file, names[exam1, exam2, admitted])data np.array(data)return datadef plot_data(X, y):plt.figure(figsize(6, 4), dpi150)X1 X[y 1, :]X2 X[…

ajax+webservice

版本為AJAX November CTP 三個示例分別為&#xff1a;1 帶參數的WS方法2 不帶參數的WS方法3 參數類型為DataTable的WS方法 一、WebMethod注意要點&#xff1a;1 WebMethod類需要添加命名空間 Microsoft.Web.Script.Services&#xff0c;此空間需要引用Microsoft.Web.Preview.dl…