首頁 後端開發 C#.Net教程 SUNWEN教程之----C#進階(八)

SUNWEN教程之----C#進階(八)

Dec 19, 2016 am 10:24 AM

這一節我要講的是大家非常關心的,肯定也是非常感興趣的部分.嘿嘿,也是我寫教程最拿手的部分----ADO數據庫訪問.想到這,我就想起我在去年寫的"訪問資料庫"系列文章,嘿嘿!所以呢,如果你覺得對記錄集之類的東西比較難理解的話,我推薦你先看一看我的那幾篇文章.好了,讓我們開始吧!

什麼是ADO(ActiveX Data Objects譯作ActiveX資料物件),ADO是一個非常簡單的思想,一種讓你僅用一種方式去存取資料的思想.ADO不算一個新的思想,僅是採用現有的資料存取技術,將其融合起來.如果你不理解ADO,想一想ODBC吧!其實我們在搞asp的時候,就用到了ADO,還記得嗎,那個曾經被我們用過無數次的set conn=Server.CreateObject("ADODB.Connection")嗎?是的,就是它.至於ADO的一些概念性的東西,請大家自行查閱資料,不過,其實不了解也沒有關係,只把它想像成一個M$給我們的存取資料的工具吧!

OK,下面的例子是以一個M$ access 2000的資料庫為基礎的,它的結構如下,表名是Categories,文件名是BugTypes.mdb ,趕快建一個吧:

Category ID Category Name 
1 Bugbash stuff 
2 Appweek Bugs 
3 .NET Reports 
4 Internal support

,我先把所有的程序都寫出來的

000: // ADOadosample.cs

001: using System;
002: using System.Data;
003: using System.Data.ADO;
004: 
005: public class MainClass 
004: 
005: public class MainClass 
006: 
005: public class MainClass 
void Main ()
008: {
009: // 設定好連接字串和選擇命令字串010: string strAccessConn = "PRovider=Microsoft.Jet.OLEDB.4.0;Data Source=BugTypes.MDB";
01111111111111111111111111111111111111113 日: string strAccessSelect = "SELECT * FROM Categories";
012: 
013: //建立記錄集,並將Categories這個表填進去
014: DataSet myDataSet = new DataSet();
015:mySetSet. "Categories");
016: 
017: //建立ADO實例018: ADOConnection myAccessConn = new ADOConnection(strAccessConn);
019: ADODataSetCommand myAccessDataSetCmd = new ADODataSetCommand(); myAccessConn);
021: 
022: myAccessConn.Open();
023: try
024: {
025: myAccessDataSetCmd.FillDataSet(myDataSet,"Categories"); 029: myAccessConn.Close();
030: }
031: 
032: try
033: {
034: // 一個記錄集可以包含多個表,我們把它們放到一個數組中035: DataTable[] dta = myDataSet.Tables.All;
036: foreach (DataTable dt in dta)
037: {
038: Console.WriteLine("Found data table {0}", dt.TableName);
039: }
40:
041: //下面的兩行程式展示了兩種從一個記錄集中得到這個資料集中的表格數的方法
042: Console.WriteLine("{0} tables in data set", myDataSet.Tables.Count) ;
043: Console.WriteLine("{0} tables in data set", dta.Length);
044: //下面的幾行程式說明如何從一個記錄集中依靠表格的名稱來取得資訊
045: Console.WriteLine("{0} rows in Categories table", myDataSet.Tables["Categories"].Rows.Count);
046: //列的資訊是自動從資料庫中得到的,所以我們可以用以下的代碼047: Console.WriteLine("{0} columns in Categories table", myDataSet.Tables["Categories"].Columns.Count);
048: DataColumn[] drc = myDataSet.Tables["Categories"]. All;
049: int i = 0;
050: foreach (DataColumn dc in drc)
051: {
052: //列印出列的下標和列的名稱和資料類型053: Console.WriteLine("Column name[{0}] is {1}, of type {2}",i++ , dc.ColumnName, dc.DataType);
054: }
055: DataRow[] dra = myDataSet.Tables["Categories"]. Rows.All;
056: foreach (DataRow dr in dra)
057: {
058: //印出CategoryID和CategoryName059: Console.WriteLine("CategoryName[{0}] is {1}", dr[0] , dr[1]);
060: }
061: }
062: catch (Exception e)
063: {
064: Console.WriteLine("Oooops. Caught an exception:n{0}", e.Message );
065: }
066: }
067: }
看起來,這個例子是有一些複雜的,只怪我例子選的不好,呵呵.不過,細細分析一下,還是可以理解的.我現在說一下這個例子中幾個特別的東東.第一就是不像在ASP中,一個命令字符串被須被當作一個命令對象.020做的正是這個事情.注意,在015行有一個myDataSet .Tables.Add("Categories")語句,這並不是把資料庫中的Categories這個表填進去,只不過是建一個空表,而025才是真的填充資料.

這個範例的輸出是:

Found data table Categories
1 tables in data set
1 tables in data set
4 rows in Categories table
2 columns in Categories table
Column name[0] isegoego, of Integories table
Column name[0] isegoegoID, 532, 1 月 Cat of type System.String
CategoryName[1] is Bugbash stuff
CategoryName[2] is Appweek Bugs
CategoryName[3] is .NET Reports
CategoryName[4] is Internal port想睡覺了,什麼音樂都不管用了,呵呵.這個例子還真要花大力氣才能完全理解.O.K.886!

 以上就是SUNWEN教程之----C#進階(八)的內容,更多相關內容請關注PHP中文網(www.php.cn)!



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1670
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1274
29
C# 教程
1256
24
使用 C# 的活動目錄 使用 C# 的活動目錄 Sep 03, 2024 pm 03:33 PM

使用 C# 的 Active Directory 指南。在這裡,我們討論 Active Directory 在 C# 中的介紹和工作原理以及語法和範例。

C# 中的隨機數產生器 C# 中的隨機數產生器 Sep 03, 2024 pm 03:34 PM

C# 隨機數產生器指南。在這裡,我們討論隨機數產生器的工作原理、偽隨機數和安全數的概念。

C# 資料網格視圖 C# 資料網格視圖 Sep 03, 2024 pm 03:32 PM

C# 資料網格視圖指南。在這裡,我們討論如何從 SQL 資料庫或 Excel 檔案載入和匯出資料網格視圖的範例。

C# 中的階乘 C# 中的階乘 Sep 03, 2024 pm 03:34 PM

C# 階乘指南。這裡我們討論 C# 中階乘的介紹以及不同的範例和程式碼實作。

c#多線程和異步的區別 c#多線程和異步的區別 Apr 03, 2025 pm 02:57 PM

多線程和異步的區別在於,多線程同時執行多個線程,而異步在不阻塞當前線程的情況下執行操作。多線程用於計算密集型任務,而異步用於用戶交互操作。多線程的優勢是提高計算性能,異步的優勢是不阻塞 UI 線程。選擇多線程還是異步取決於任務性質:計算密集型任務使用多線程,與外部資源交互且需要保持 UI 響應的任務使用異步。

C# 中的模式 C# 中的模式 Sep 03, 2024 pm 03:33 PM

C# 模式指南。在這裡,我們討論 C# 中模式的介紹和前 3 種類型,以及其範例和程式碼實作。

C# 中的質數 C# 中的質數 Sep 03, 2024 pm 03:35 PM

C# 質數指南。這裡我們討論c#中素數的介紹和範例以及程式碼實作。

xml怎麼改格式 xml怎麼改格式 Apr 03, 2025 am 08:42 AM

可以採用多種方法修改 XML 格式:使用文本編輯器(如 Notepad )進行手工編輯;使用在線或桌面 XML 格式化工具(如 XMLbeautifier)進行自動格式化;使用 XML 轉換工具(如 XSLT)定義轉換規則;或者使用編程語言(如 Python)進行解析和操作。修改時需謹慎,並備份原始文件。

See all articles