前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ExecuteScalar()方法

ExecuteScalar()方法

作者头像
全栈程序员站长
发布2022-09-07 10:30:08
2970
发布2022-09-07 10:30:08
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

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()方法来获取刚刚更新后第一行第一列的值。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/147736.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档