国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ASP.NET 2.0中執行數據庫操作命令之一_.Net教程

2024-07-10 12:50:09
字體:
來源:轉載
供稿:網友

推薦:.NET vs J2EE――面對SOA的荒謬與誤解
·.Net與J2EE在金融行業愈來愈呈勢均力敵之勢,二者均宣稱提供了不同于對方的、聽起來很迷人的個性化應用服務。·理性的IT執行官們已經深刻的認識到這樣的一個事實:無論是.Net

數據庫命令執行時使用Command對象。Command類有三種:SqlCommand、OleDbCommand與OdbcCommand。

Command對象主要用來運行SELECT、INSERT、UPDATE或DELETE之類的SQL語句。Command對象還可以調用存儲過程或從特定表中取得記錄。

DataReader對象主要是用來讀取數據結果,使用它讀取記錄時通常比從DataSet更快。DataReader類有三種:SqlDataReader、OleDbDataReader和OdbcDataReader。DataReader對象用Commmand對象從數據庫中讀取記錄,并且DataReader對象只能向前的讀取記錄,用于在某些情況下替代DataSet對象(DataSet對象可以存儲數據庫中的行拷貝,可以在切斷數據庫的連接時處理這個拷貝,我們將在以后的章節中詳細介紹該對象)。

注意:不能用DataReader修改數據庫中的記錄,它是采用向前的,只讀的方式讀取數據庫。

SqlCommand類

SqlCommand對象用于對SQL Server數據庫執行命令。OleDbCommand對象用于對支持OleDb的數據庫執行命令,如Oracle與ACCESS。

OdbcCommand對象用于對支持Odbc的數據庫執行命令。盡管SqlCommand類是針對SQL Server的,但是這個類的許多屬性、方法與事件和

OleDbCommand及OdbcCommand等類相似。本章將重點講解SqlCommand特定的屬性與方法,其他的Command類你可以參考相應的幫助文檔。

注意:使用不同的Command對象需要導入不同的命名空間。OleDbCommand的命名空間為System.Data.OleDb。SqlCommand的命名空間為System.Data.SqlClient。OdbcCommand的命名空間為System.Data.Odbc。

SqlCommand屬性:

屬性 說明

CommandText 其返回類型為string, 獲取或設置要對數據源執行的 SQL 語句、存儲過程或表。

CommandTimeOut 其返回類型為int,獲取或設置在終止執行命令的嘗試并生成錯誤之前的等待時間。

CommandType 其返回類型為CommandType,讀取或設置表示CommandText屬性將如何被解釋的值,其有效的值可以為CommandType.Text、CommandType.StoredProcedur與CommandType.TableDirect,分別表示SQL語句、存儲過程調用或要讀取的表,默認為Text。

Connection 其返回類型為string, 獲取或設置 SqlCommand 的此實例使用的 SqlConnection。

Parameters 其返回類型為SqlParameterCollection,取得提供給命令的參數(如有)。

SqlCommand方法:

方法 說明

Cancle() 其返回類型為void,取消命令的執行

CreateParameter() 其返回類型為SqlParameter, 用于創建 SqlParameter 對象的新實例。

ExecuteNonQuery() 其返回類型為int,執行不返回結果集的Sql語句,包括INSERT、UPDATE與DELETE語句、DDL語句和不返回結果集的存儲過程調用。返回的int值是命令影響的數據庫行數。

ExecuteReader() 其返回類型為SqlDataReader, 執行SELECT語句、TableDirect命令或返回結果集的存儲過程調用。在SqlDataReader對象中返回結果集。

ExecuteScalar() 其返回類型為object,執行返回單個值的SELECT語句(任何其他的值將被忽略)。這個命令結果作為對象被返回。

ExecuteXMLReader() 其返回類型為XmlReader,執行返回XML數據的SELECT語句,用XMLReader對象返回結果集,只適用于SqlCommand類

生成SqlCommand對象

我們可以用構造函數生成SqlCommand對象,也可以調用SqlConnection對象的CreateCommand()方法生成SqlCommand對象,下面分別介紹這兩種方法。

用構造函數生成SqlCommand對象

SqlCommand對象的構造函數如下所示:

SqlCommand()

SqlCommand(string commandText)

SqlCommand(string commandText,SqlConnection MySQLConnection)

程序代碼說明:在上述語法范例的程序代碼中,commandText包含SQL語句、存儲過程調用或要讀取的表。MySQLConnection是對應的SqlConnection對象。

在使用SqlCommand對象之前,首先要確定一個SqlConnection對象,用于和SQL Server數據庫進行數據傳遞。

MySQLConnection.ConnectionString="server=localhost;database=Northwind;
integrated security=SSPI";

然后可以用下列語句生成新的SqlCommand對象:

SqlCommand MySQLCommand=new SqlCommand();

再將mySqlCommand對象的Connection屬性設置為MySQLConnection:

mySqlCommand.Connection= MySQLConnection;

這樣mySqlCommand對象就可以使用MySQLConnection與數據庫進行數據傳遞。現在,Command對象的CommandType屬性確定要執行的命令類型。可以用System.Data.CommandType枚舉值指定CommandType屬性。

CommandType的枚舉值如下表所示:

數值 說明

Text 表示命令是SQL語句,默認值是Text

StoredProcedure 表示命令是儲存過程調用

TableDirect 表示被讀取的行和列的表名。注意:SqlCommand對象不支持TableDirect,要使用其他的Command類的對象。

例如你可以采用如下的形式執行一個SQL查詢:

以下為引用的內容:
SqlCommand MySQLCommand=new SqlCommand();
mySqlCommand.Connection=MySQLConnection;
MySQLCommand.CommandText=”SELECT * FROM Employees”;
//MySQLCommand.CommandType=CommandType.Text;

程序代碼說明:在上述語法范例的程序代碼中,我們設置了mySqlCommand對象的commandText為一個SELECT查詢語句,并且指定了MySQLCommand對象的CommandType屬性為CommandType.Text,表示命令是SQL語句。由于CommandType.Text是默認的CommandType值,所以我們可以將其注譯掉。

還有一個更具效率的形式,那就是使用SqlCommand對象的其中一種構造函數:

SqlCommand MySQLCommand=new SqlCommand(”SELECT * FROM Employees”,myConnection);

程序代碼說明:在上述語法范例的程序代碼中,我們可以直接利用SqlCommand(string commandText,SqlConnection MySQLConnection) 構造函數,從而使得程序代碼更加的簡練和直觀。

還可以使用儲存過程來查詢所需要的數據,我們可以采用如下的代碼形式:

以下為引用的內容:
SqlCommand MySQLCommand=new SqlCommand(”GetEmpolyees”,myConnection);
MySQLCommand.CommandType=CommandType.StoredProcedure;

程序代碼說明:在上述語法范例的程序代碼中,GetEmpolyees為一個儲存過程名,用來實現所有的雇員信息查詢。并且將CommandType值指定為StoredProcedure,表示命令是儲存過程調用。

使用CreateCommand()方法生成SqlCommand對象

如果不用構造函數,也可以使用SqlConnection對象的CreateCommand()方法生成SqlCommand對象。這個方法返回新的SqlCommand對象。例如:

SqlCommand mySqlCommand=MySQLConnection.CreateCommand();

分享:ASP.NET多頻道網站架構實現方法
各頻道分別位于不同的Web Project(具有獨立的二級域名),并將所有的業務邏輯以及數據訪問功能封裝成Class Library,所有頻道共用這個Class Library。下面詳細介紹實現方法。假設網站有三

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 遂宁市| 盐城市| 开封市| 犍为县| 桐柏县| 阜新| 威海市| 凤翔县| 乃东县| 汉阴县| 聂荣县| 桂东县| 潍坊市| 海城市| 军事| 濮阳市| 江山市| 酒泉市| 舞钢市| 个旧市| 嘉义市| 涞源县| 凤城市| 调兵山市| 丰都县| 九龙城区| 临汾市| 固始县| 凤山县| 湖州市| 来宾市| 余干县| 宁城县| 托里县| 威信县| 关岭| 新化县| 平邑县| 宜良县| 什邡市| 嘉鱼县|