ASP.Net中命名空間Namespace淺析和使用例子
來(lái)源:易賢網(wǎng) 閱讀:879 次 日期:2014-08-11 11:19:24
溫馨提示:易賢網(wǎng)小編為您整理了“ASP.Net中命名空間Namespace淺析和使用例子”,方便廣大網(wǎng)友查閱!

關(guān)于Namespace(命名空間)的使用,我常用

代碼如下:

< % @ Import Namespace="System.Data" %>

,這是在引用為我們提供的Namespace,這和ASP不同的,我們?cè)贏SP.net必須先引用與我們操作有關(guān)的Namespace后才能使用相應(yīng)的功能。其實(shí)說(shuō)白了,一個(gè)Namespace; 就是一個(gè)組件。

這個(gè)是關(guān)于ASP.net的高級(jí)應(yīng)用。

我下面簡(jiǎn)單的列舉一些常用的Namespace

代碼如下:

< % @ Import Namespace="System.Data" %> 處理數(shù)據(jù)時(shí)用到

< % @ Import Namespace="System.Data.ADO" % > 使用ADO.net ; 時(shí)用到

< % @ Import Namespace="System.Data.SQL" %> SQL Server 數(shù)據(jù)庫(kù)專(zhuān)用

< % @ Import Namespace="System.Data.XML" %> 不用看處理XML用到

< % @ Import Namespace="System.IO" %> 處理文件時(shí)用到

< % @ Import Namespace="System.Web.Util" %> 發(fā)郵件時(shí)大家會(huì)用到

< % @ Import Namespace="System.Text" %> 文本編碼時(shí)用到

操作數(shù)據(jù)庫(kù)需要的東東

講解了Namespace,我們可以正式來(lái)討論數(shù)據(jù)庫(kù)的應(yīng)用了。

從上面的可以看出,我們操作數(shù)據(jù)庫(kù),我們需要引用下面兩個(gè)Namespace

代碼如下:

< % @ Import Namespace="System.Data" %>

< % @ Import Namespace="System.Data.SQL" %>

其實(shí)System.Data.SQL 可以用System.Data.ADO來(lái)代替,SQL是SQL Server專(zhuān)用,ADO可以支持任何數(shù)據(jù)庫(kù)(只要在主機(jī)上存在相應(yīng)的驅(qū)動(dòng)就行了,如Access,Mysql,Oracle之類(lèi)的)。

無(wú)論是ADO還是SQL ,他們都有幾個(gè)基本的對(duì)象用于操作

代碼如下:

Connections 連結(jié)到一個(gè)數(shù)據(jù)庫(kù),以便于后面的應(yīng)用(類(lèi)似ADO中的Connections)

Commands 執(zhí)行SQL語(yǔ)句的地方

DataReader 讀取執(zhí)行后返回的數(shù)據(jù)內(nèi)容

DataSet 儲(chǔ)存數(shù)據(jù),功能強(qiáng)大,我們會(huì)具體講解

DataSetCommand 執(zhí)行SQL語(yǔ)句,并把數(shù)據(jù)存入DataSet

這里面可能最難理解的就是DataSet,我們先不去管他。

Connections(SQLConection 或者 ADOConnection)

它的主要任務(wù)就是建立一個(gè)與數(shù)據(jù)庫(kù)服務(wù)器的連接

代碼如下:

< % @ Page Language="C#" %>

< % @ Import Namespace="System.Data" %>

< % @ Import Namespace="System.Data.SQL" %>

<script Language= "C#" Runat= "Server">

public void Page_Load(Object src,EventArgs e)

{

stringstrProvider="server=localhost;uid=sa;pwd=;database=aspcn";

SQLConnection MyConnection=new SQLConnection(strProvider);

}

</script>

上面我們建立了一個(gè)名為MyConnection的聯(lián)結(jié),就好像我們?cè)贏SP中用ADODB.Connection打開(kāi)了一個(gè)聯(lián)結(jié),這個(gè)聯(lián)結(jié)我們?cè)贑ommand或者DataSetCommand中將會(huì)使用。

它的一些有用的屬性和方法有

代碼如下:

ConnectionString 取得或設(shè)置連結(jié)數(shù)據(jù)庫(kù)的語(yǔ)句

ConnectionTimeout 取得或設(shè)置連結(jié)數(shù)據(jù)庫(kù)的最長(zhǎng)時(shí)間,也是就超時(shí)時(shí)間

DataBase 取得或設(shè)置在數(shù)據(jù)庫(kù)服務(wù)器上要打開(kāi)的數(shù)據(jù)庫(kù)名

DataSource 取得或設(shè)置DSN,大家不會(huì)陌生吧:)

Password 取得或設(shè)置密碼

UserID 取得或設(shè)置登陸名

State 取得目前聯(lián)結(jié)的狀態(tài)

Open() 打開(kāi)聯(lián)結(jié)

Close() 關(guān)閉聯(lián)結(jié)

Clone() 克隆一個(gè)聯(lián)結(jié)。

我們也通過(guò)一個(gè)小例子來(lái)看看他們的用法:

代碼如下:

SQLConnection myConnection = new SQLConnection();

myConnection.DataSource = "mySQLServer";

myConnection.Password = "";

myConnection.UserID = "sa";

myConnection.ConnectionTimeout = 30;

myConnection.Open();

myConnection.Database = "northwind";

myConnection.IsolationLevel = IsolationLevel.ReadCommitted

 

Commands(SQLCommand 或者 ADOCommand)

上面的程序中我們打開(kāi)了一個(gè)聯(lián)結(jié),這里我們就需要來(lái)使用這個(gè),看例子比較好:

代碼如下:

< % @ Page Language="C#" %>

< % @ Import Namespace="System.Data" %>

< % @ Import Namespace="System.Data.SQL" %>

<script Language="C#" Runat="Server">

public void Page_Load(Object src,EventArgs e)

{

stringstrProvider="server=localhost;uid=sa;pwd=;database=aspcn";

string strIndex="select * from aspcn where purview='webmaster'";

SQLConnection MyConnection=new SQLConnection(strProvider);

SQLCommand MyCommand = new SQLCommand(strIndex,MyConnection);

MyConnection.Open(); //打開(kāi)聯(lián)結(jié)

MyCommand.ExecuteNonQuery(); //執(zhí)行SQL,但不返回任何記錄

MyConnection.Close();

}

</script>

在上面的例子中我們建立SQLCommand對(duì)象時(shí)引用了兩個(gè)參數(shù)(strIndex,MyConnection),從源程序中我們也可以看出來(lái)strIndex代表的是執(zhí)行的SQL語(yǔ)句,MyConnection是我們先前建立的聯(lián)結(jié).然后我們就要先打開(kāi)MyConnnection,然后再執(zhí)行這個(gè)SQL語(yǔ)句。

我們?cè)谶@里執(zhí)行用的是ExecuteNonQuery()方法,這樣不返回記錄集,只是返回受影響的記錄個(gè)數(shù)。

這里我們打開(kāi)和關(guān)閉數(shù)據(jù)庫(kù)也可以這樣做。

代碼如下:

stringstrProvider="server=localhost;uid=sa;pwd=;database=aspcn";

string strIndex="select * from aspcn where purview='webmaster'";

SQLConnection MyConnection=new SQLConnection(strProvider);

SQLCommand MyCommand = new SQLCommand(strIndex,MyConnection);

MyCommand.ActiveConnection.Open();

MyCommand.ExecuteNonQuery();

MyCommand.ActiveConnection.Close();

所得結(jié)果和先前的一樣。所以執(zhí)行一條SQL語(yǔ)句有很多種方法。而且還不只兩種,我們后面學(xué)了DataSetCommand,那打開(kāi)方法就是N種了:)這就需要看你的習(xí)慣和程序的要求了;)

我們先來(lái)看看Command常用的方法和屬性

代碼如下:

ActiveConnection 取得或設(shè)置聯(lián)結(jié)Connections

CommandText 執(zhí)行的SQL語(yǔ)句或儲(chǔ)存過(guò)程(StoredProcedure)名

CommandTimeout 執(zhí)行的最長(zhǎng)時(shí)間

CommandType Command操作的類(lèi)型(StoredProcedure,Text,TableDirect)三種,默認(rèn)Text

Parameters 操作儲(chǔ)存過(guò)程時(shí)使用

Execute() 執(zhí)行SQL語(yǔ)句或儲(chǔ)存過(guò)程

ExecuteNonQuery() 同上,區(qū)別在于不返回記錄集

Clone() 克隆Command

同樣看一個(gè)例子:

string mySelectQuery = "SELECT * FROM Categories ORDER BY CategoryID";

stringmyConnectString="userid=sa;password=;database=northwind;server=mySQLServer";

SQLCommand myCommand = new SQLCommand(mySelectQuery);

myCommand.ActiveConnection = new SQLConnection(myConnectString);

myCommand.CommandTimeout = 15;

myCommand.CommandType = CommandType.Text;

更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:ASP.Net中命名空間Namespace淺析和使用例子
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
咨詢(xún)QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)