溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

C#中ExecuteScalar()方法的用法

發(fā)布時(shí)間:2021-08-20 19:39:24 來(lái)源:億速云 閱讀:712 作者:chen 欄目:開(kāi)發(fā)技術(shù)

本篇內(nèi)容主要講解“C#中ExecuteScalar()方法的用法”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“C#中ExecuteScalar()方法的用法”吧!

1、返回的是一個(gè)object類(lèi)型,也就是說(shuō)是所有數(shù)據(jù)類(lèi)型的基類(lèi),可根據(jù)select所得的第一列的數(shù)據(jù)類(lèi)型轉(zhuǎn)換為對(duì)應(yīng)的數(shù)據(jù)類(lèi)型

例:

string strConn = "Data Source=(local);Initial Catalog=paperManage;Integrated Security=True";
SQLConnection objConn = new SQLconnection(strConn);
SQLCommand objCMD = new SQLCommand(strSQL,objConn);
object objResult = objCMD.ExecuteScalar() //或者 string result = objCMD.ExecuteScalar().toString();

2、當(dāng)select語(yǔ)句無(wú)記錄返回時(shí),ExecuteScalar()返回NULL值,無(wú)法再將null值賦給任何對(duì)象或者變量,否則出現(xiàn)異常:System.NullReferenceException:   未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例

例:

若select查詢無(wú)返回記錄,以下代碼則會(huì)拋出異常:

try
{
   string result = objCMD.ExecuteScalar().toString();
}
catch(SQLException ee)
{
   MessageBox.show(ee.toString());
}

解決方法是先判斷ExecuteScalar()是否為null,再進(jìn)行相應(yīng)的處理。

例:

if (objCMD.ExecuteScalar() == null) {
    //為空時(shí)的操作
} else {
    result = objCMD.ExecuteScalar().ToString().Trim();
}

使用 ExecuteScalar() 方法從數(shù)據(jù)庫(kù)中檢索單個(gè)值(例如一個(gè)聚合值)。

典型的 ExecuteScalar() 查詢可以采用類(lèi)似于下面的 C# 示例的格式:

cmd.CommandText = "SELECT COUNT(*) FROM dbo.region";
Int32 count = (Int32) cmd.ExecuteScalar();

到此,相信大家對(duì)“C#中ExecuteScalar()方法的用法”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI