关于ADO.NET ExecuteScalar方法揭秘
创始人
2024-06-10 14:40:16
0

ADO.NET访问数据库这门技术想必大家都知道的吧,有很多东西值得我们学习,这里就ADO.NET ExecuteScalar方法来简单的介绍一下吧,以后还会介绍更多的方法的。若您程序中执行的 SQL statement 或 Stored Procedure,只是要返回计算过的「单一值」,例如:SELECT Count(*) FROM 员工数据表。或只会回传符合条件的「第一笔」record 的「第一个」column 其值,例如:SELECT 电子信箱 FROM 员工数据表 WHERE 姓名= 'David'。

#T#我们即可用 Command 对象的 ExecuteScalar 方法 (ADO.NET 1.x 即支援。DbCommand 对象则要 .NET 2.0 才支持),以回传数据集中第一个 row 的第一个 column 其存储值,并忽略其它无用的数据;此种做法比起用ExecuteReader 方法回传「多组」record,再指定给 DataReader 对象,再逐一比对数据,可更有效地节省系统资源并提升「性能 (performance)」。

但由于 ExecuteScalar 方法回传的必为 Object 类型,因此必须由程序员,手动将其强制转型为 .NET 的 int 或 string 等想要的类型,以便直接指派给 int 或 string 类型的变量,或显示在页面上的控件中,如下ADO.NET ExecuteScalar方法所示:

  1. string theMail = (string)cmd.ExecuteScalar(); 

因此使用 ADO.NET ExecuteScalar方法时,在程序中必须先确定,承接回传值的变量其类型为何,否则会发生转型错误。此外,在上例中,若「员工数据表」内有超过一个以上叫做「David」的员工,则 ExecuteScalar 方法只会回传「第一个」叫做 David 的员工其电子信箱,而忽略其它亦符合条件的数据。

此外,ExecuteScalar 方法不只可以用在数据库的 SELECT 作业,亦可用于 INSERT 作业。假设我们想要在 INSERT 一笔 record 至数据库后,马上取得刚才新增那一笔 record 的 Identity (自动增号) 的值,可用下列 SQL statement 达成:

  1. string strSql = "INSERT INTO 数据表 (name, age) VALUES ('David', 20); Select @@Identity"

此时,我们即可用ADO.NET ExecuteScalar方法,取代 ExecuteNonQuery 方法,去执行上述这一段 SQL statement,以便返回一笔计算过的「单一值」,亦即最新的 Identity 流水号码,关键 ADO.NET 代码如下:

  1. SqlConnection conn = new SqlConnection(strConnString);  
  2. SqlCommand cmd = new SqlCommand(strSqlStr, conn);  
  3. try  
  4. {  
  5. conn.Open();  
  6. if (conn.State == ConnectionState.Open)  
  7. {  
  8. // 返回最新的 Identity 流水号码  
  9. intNewestSerialNum = Convert.ToInt32(cmd.ExecuteScalar());  
  10. }  
  11. }  
  12. catch (SqlException ex)  
  13. {  
  14. }  

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...