ASP.NET 2.0中執(zhí)行數(shù)據(jù)庫操作命令之一_.Net教程
推薦:.NET vs J2EE——面對SOA的荒謬與誤解·.Net與J2EE在金融行業(yè)愈來愈呈勢均力敵之勢,二者均宣稱提供了不同于對方的、聽起來很迷人的個性化應用服務。 ·理性的IT執(zhí)行官們已經(jīng)深刻的認識到這樣的一個事實:無論是.Net
數(shù)據(jù)庫命令執(zhí)行時使用Command對象。Command類有三種:SqlCommand、OleDbCommand與OdbcCommand。
Command對象主要用來運行SELECT、INSERT、UPDATE或DELETE之類的SQL語句。Command對象還可以調(diào)用存儲過程或從特定表中取得記錄。
DataReader對象主要是用來讀取數(shù)據(jù)結(jié)果,使用它讀取記錄時通常比從DataSet更快。DataReader類有三種:SqlDataReader、OleDbDataReader和OdbcDataReader。DataReader對象用Commmand對象從數(shù)據(jù)庫中讀取記錄,并且DataReader對象只能向前的讀取記錄,用于在某些情況下替代DataSet對象(DataSet對象可以存儲數(shù)據(jù)庫中的行拷貝,可以在切斷數(shù)據(jù)庫的連接時處理這個拷貝,我們將在以后的章節(jié)中詳細介紹該對象)。
注意:不能用DataReader修改數(shù)據(jù)庫中的記錄,它是采用向前的,只讀的方式讀取數(shù)據(jù)庫。
SqlCommand類
SqlCommand對象用于對SQL Server數(shù)據(jù)庫執(zhí)行命令。OleDbCommand對象用于對支持OleDb的數(shù)據(jù)庫執(zhí)行命令,如Oracle與ACCESS。
OdbcCommand對象用于對支持Odbc的數(shù)據(jù)庫執(zhí)行命令。盡管SqlCommand類是針對SQL Server的,但是這個類的許多屬性、方法與事件和
OleDbCommand及OdbcCommand等類相似。本章將重點講解SqlCommand特定的屬性與方法,其他的Command類你可以參考相應的幫助文檔。
注意:使用不同的Command對象需要導入不同的命名空間。OleDbCommand的命名空間為System.Data.OleDb。SqlCommand的命名空間為System.Data.SqlClient。OdbcCommand的命名空間為System.Data.Odbc。
SqlCommand屬性:
屬性 說明
CommandText 其返回類型為string, 獲取或設置要對數(shù)據(jù)源執(zhí)行的 SQL 語句、存儲過程或表。
CommandTimeOut 其返回類型為int,獲取或設置在終止執(zhí)行命令的嘗試并生成錯誤之前的等待時間。
CommandType 其返回類型為CommandType,讀取或設置表示CommandText屬性將如何被解釋的值,其有效的值可以為CommandType.Text、CommandType.StoredProcedur與CommandType.TableDirect,分別表示SQL語句、存儲過程調(diào)用或要讀取的表,默認為Text。
Connection 其返回類型為string, 獲取或設置 SqlCommand 的此實例使用的 SqlConnection。
Parameters 其返回類型為SqlParameterCollection,取得提供給命令的參數(shù)(如有)。
SqlCommand方法:
方法 說明
Cancle() 其返回類型為void,取消命令的執(zhí)行
CreateParameter() 其返回類型為SqlParameter, 用于創(chuàng)建 SqlParameter 對象的新實例。
ExecuteNonQuery() 其返回類型為int,執(zhí)行不返回結(jié)果集的Sql語句,包括INSERT、UPDATE與DELETE語句、DDL語句和不返回結(jié)果集的存儲過程調(diào)用。返回的int值是命令影響的數(shù)據(jù)庫行數(shù)。
ExecuteReader() 其返回類型為SqlDataReader, 執(zhí)行SELECT語句、TableDirect命令或返回結(jié)果集的存儲過程調(diào)用。在SqlDataReader對象中返回結(jié)果集。
ExecuteScalar() 其返回類型為object,執(zhí)行返回單個值的SELECT語句(任何其他的值將被忽略)。這個命令結(jié)果作為對象被返回。
ExecuteXMLReader() 其返回類型為XmlReader,執(zhí)行返回XML數(shù)據(jù)的SELECT語句,用XMLReader對象返回結(jié)果集,只適用于SqlCommand類
生成SqlCommand對象
我們可以用構(gòu)造函數(shù)生成SqlCommand對象,也可以調(diào)用SqlConnection對象的CreateCommand()方法生成SqlCommand對象,下面分別介紹這兩種方法。
用構(gòu)造函數(shù)生成SqlCommand對象
SqlCommand對象的構(gòu)造函數(shù)如下所示:
SqlCommand()
SqlCommand(string commandText)
SqlCommand(string commandText,SqlConnection MySQLConnection)
程序代碼說明:在上述語法范例的程序代碼中,commandText包含SQL語句、存儲過程調(diào)用或要讀取的表。MySQLConnection是對應的SqlConnection對象。
在使用SqlCommand對象之前,首先要確定一個SqlConnection對象,用于和SQL Server數(shù)據(jù)庫進行數(shù)據(jù)傳遞。
MySQLConnection.ConnectionString="server=localhost;database=Northwind;
integrated security=SSPI";
然后可以用下列語句生成新的SqlCommand對象:
SqlCommand MySQLCommand=new SqlCommand();
再將mySqlCommand對象的Connection屬性設置為MySQLConnection:
mySqlCommand.Connection= MySQLConnection;
這樣mySqlCommand對象就可以使用MySQLConnection與數(shù)據(jù)庫進行數(shù)據(jù)傳遞。現(xiàn)在,Command對象的CommandType屬性確定要執(zhí)行的命令類型。可以用System.Data.CommandType枚舉值指定CommandType屬性。
CommandType的枚舉值如下表所示:
數(shù)值 說明
Text 表示命令是SQL語句,默認值是Text
StoredProcedure 表示命令是儲存過程調(diào)用
TableDirect 表示被讀取的行和列的表名。注意:SqlCommand對象不支持TableDirect,要使用其他的Command類的對象。
例如你可以采用如下的形式執(zhí)行一個SQL查詢:
| 以下為引用的內(nèi)容: 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對象的其中一種構(gòu)造函數(shù):
SqlCommand MySQLCommand=new SqlCommand(”SELECT * FROM Employees”,myConnection);
程序代碼說明:在上述語法范例的程序代碼中,我們可以直接利用SqlCommand(string commandText,SqlConnection MySQLConnection) 構(gòu)造函數(shù),從而使得程序代碼更加的簡練和直觀。
還可以使用儲存過程來查詢所需要的數(shù)據(jù),我們可以采用如下的代碼形式:
| 以下為引用的內(nèi)容: SqlCommand MySQLCommand=new SqlCommand(”GetEmpolyees”,myConnection); MySQLCommand.CommandType=CommandType.StoredProcedure; |
程序代碼說明:在上述語法范例的程序代碼中,GetEmpolyees為一個儲存過程名,用來實現(xiàn)所有的雇員信息查詢。并且將CommandType值指定為StoredProcedure,表示命令是儲存過程調(diào)用。
使用CreateCommand()方法生成SqlCommand對象
如果不用構(gòu)造函數(shù),也可以使用SqlConnection對象的CreateCommand()方法生成SqlCommand對象。這個方法返回新的SqlCommand對象。例如:
SqlCommand mySqlCommand=MySQLConnection.CreateCommand();
分享:ASP.NET多頻道網(wǎng)站架構(gòu)實現(xiàn)方法各頻道分別位于不同的Web Project(具有獨立的二級域名),并將所有的業(yè)務邏輯以及數(shù)據(jù)訪問功能封裝成Class Library,所有頻道共用這個Class Library。 下面詳細介紹實現(xiàn)方法。 假設網(wǎng)站有三
- asp.net如何得到GRIDVIEW中某行某列值的方法
- .net SMTP發(fā)送Email實例(可帶附件)
- js實現(xiàn)廣告漂浮效果的小例子
- asp.net Repeater 數(shù)據(jù)綁定的具體實現(xiàn)
- Asp.Net 無刷新文件上傳并顯示進度條的實現(xiàn)方法及思路
- Asp.net獲取客戶端IP常見代碼存在的偽造IP問題探討
- VS2010 水晶報表的使用方法
- ASP.NET中操作SQL數(shù)據(jù)庫(連接字符串的配置及獲取)
- asp.net頁面?zhèn)髦禍y試實例代碼
- DataGridView - DataGridViewCheckBoxCell的使用介紹
- asp.net中javascript的引用(直接引入和間接引入)
- 三層+存儲過程實現(xiàn)分頁示例代碼
- 相關(guān)鏈接:
- 教程說明:
.Net教程-ASP.NET 2.0中執(zhí)行數(shù)據(jù)庫操作命令之一
。