首页 > 技术文章 > SQL之ExecuteScalar()

ZkbFighting 2017-11-21 16:44 原文

ExecuteScalar这个方法是从数据库中检索单个值返回值是object类型,必须用与它在数据库里存放的类型相同类型或者可以转换成的类型,
比如数据是nchar类型值为 "123" 就可以用(int)ExecuteScalar(),
如果数据是nchar类型值为 "abc"就不能用(int)ExecuteScalar(),就得写string result = ExecuteScalar().ToString

ExecuteScalar 的规则就是返回第一列,第一行的数据。
如果第一列第一行不为空,那么ExecuteScalar就直接对应的DotNet的值。
如果有第一行,但是第一列为空,那么返回的是 DBNull 。
如果一行都没有,那么ExecuteScalar就返回null

这里容易犯的一个错误是,把ExecuteScalar返回DBNull与null的情况混淆,例如:
string username=cmd.ExecuteScalar().ToString();
除非你认为cmd执行后,肯定至少有一行数据,否则这里就会出错。

 

ExecuteScalar()方法也用来执行SQL语句,但是ExecuteScalar()执行SQL语句后的返回值与ExecuteNonQuery()并不相同,
ExecuteScalar()方法的返回值的数据类型是Object类型。
如果执行的SQL语句是一个查询语句(SELECT),则返回结果是查询后的第一行的第一列,
如果执行的SQL语句不是一个查询语句,则会返回一个未实例化的对象,必须通过类型转换来显示,
示例代码如下所示。

string str = "server='(local)';database='mytable';uid='sa';pwd='sa'"; //创建连接字串
SqlConnection con = new SqlConnection(str);      //创建连接对象
con.Open();//打开连接
string strsql = "select * from mynews order by id desc";
SqlCommand cmd = new SqlCommand(strsql, con);
Label1.Text = "查询出了Id为" + cmd.ExecuteScalar() \; //使用ExecuteScalar查询

通常情况下ExecuteNonQuery()操作后返回的是一个值,

而ExecuteScalar()操作后则会返回一个对象,ExecuteScalar()经常使用于当需要返回单一值时的情况。
例如当插入一条数据信息时,常常需要马上知道刚才插入的值,则可以使用ExecuteScalar()方法。示例代码如下所示

string str = "server='(local)';database='mytable';uid='sa';pwd='sa'";       //创建连接字串
SqlConnection con = new SqlConnection(str);  //创建连接对象
con.Open(); //打开连接
string strsql = "insert into mynews values ('刚刚插入的id是多少?')
SELECT  @@IDENTITY  as  'bh'"; //插入语句
SqlCommand cmd = new SqlCommand(strsql, con);//执行语句
Label1.Text = "刚刚插入的行的id是" + cmd.ExecuteScalar();//返回赋值

上述代码使用了SELECT  @@IDENTITY语法获取刚刚执行更新后的id值,然后通过使用ExecuteScalar()方法来获取刚刚更新后第一行第一列的值。

推荐阅读