ADO.NET---ExcuteScalar()方法复习
ExcuteScalar(),返回的是查询结果的第一行第一列,返回值是object类型,一般用来查询表中有多少条数据,求最大值等
现在我们用ExcuteScalar()做个测试,需求:我要查询学生表里面有多少条数据.
存储过程:
IF OBJECT_ID('GetStudentsCountNum','P') IS NOT NULL
DROP PROCEDURE GetStudentsCountNum
GO
CREATE PROCEDURE GetStudentsCountNum
AS
SELECT COUNT (*) FROM dbo.T_USERS
GO
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;
using System.Data.SqlClient;
namespace ADO.NET查询结果集的第一行第一列
{
class Program
{
static void Main(string[] args)
{
//连接字符串
string sqlConStr = "server=.;database=DB_USERS;uid=sa;pwd=Password_1";
//1.创建连接对象
SqlConnection scon = new SqlConnection(sqlConStr);
//2.创建命令对象
SqlCommand scmd = new SqlCommand();
scmd.CommandText = "GetStudentsCountNum";
scmd.CommandType = CommandType.StoredProcedure;
scmd.Connection = scon;
//3.打开连接
scon.Open();
//4,执行命令
int result = (int)scmd.ExecuteScalar();
//5.处理数据
Console.WriteLine("查询到的数据行总数是{0}", result);
//6。关闭连接
scon.Close();
Console.ReadKey();
}
}
}
ExcuteScalar()方法测试
程序执行效果图:

然而ExcuteScalar还有一个特别的应用。
比如,我有一个数据库表,主键是自动增长的,大家都知道,这个时候,向表里面插入数据,不能插入自动增长的主键字段,但是我现在有这样一个需求:
我要得到每次插入到表中的数据的主键值。。这个时候,就轮到ExcuteScalar出马了。所以这个时候,我们可以得出结论:我们不要以为只有select操作的时候才去用ExcuteScalar,像这个Insert操作由于输出的是一行一列的值,也可以使用ExcuteScalar方法。
具体的使用方法是。在插入语句的values关键字前面加上 output inserted.ID ,这里的ID指的是主键字段。
创建存储过程:(等等我们这里创建两个,一个是错误的实例,一个是正确的实例)
IF OBJECT_ID('Insert_Users','P') IS NOT NULL
DROP PROCEDURE Insert_Users
GO
CREATE PROCEDURE Insert_Users
@name NVARCHAR() ,
@pwd NVARCHAR (),
@age INT ,
@errorTimes INT
AS
INSERT INTO dbo.T_USERS
( T_NAME, T_PWD, T_AGE, T_ErrorTimes )
OUTPUT Inserted.T_ID VALUES ( )
)
'@age', -- T_AGE - int
'@errorTimes' -- T_ErrorTimes - int
)
GO
错误实例,:age和errorTimes字段在数据库中是int类型的,在创建存储过程的时候,不能给参数加引号,不然在编写程序的时候,报错

即使在程序中,单独对这个参数,申明int类型的参数,也还是报错。所以要特别注意。
正确的存储过程实例:
IF OBJECT_ID('Insert_Users','P') IS NOT NULL
DROP PROCEDURE Insert_Users
GO
CREATE PROCEDURE Insert_Users
@name NVARCHAR() ,
@pwd NVARCHAR (),
@age INT ,
@errorTimes INT
AS
INSERT INTO dbo.T_USERS
( T_NAME, T_PWD, T_AGE, T_ErrorTimes )
OUTPUT Inserted.T_ID VALUES ( @name, -- T_NAME - nvarchar()
@pwd, -- T_PWD - nvarchar()
@age, -- T_AGE - int
@errorTimes -- T_ErrorTimes - int
)
GO
正确的存储过程实例
代码实现如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;
using System.Data.SqlClient;
namespace 当主键是自动增长的时候_我们要查询每次插入的时候的主键值的时候用ExcuteScalar
{
class Program
{
static void Main(string[] args)
{
string sqlConStr = "server=.;database=DB_USERS;uid=sa;pwd=Password_1";
//1.创建连接对象
SqlConnection scon = new SqlConnection(sqlConStr);
//2.创建命令对象
SqlCommand scmd = new SqlCommand();
scmd.CommandText = "Insert_Users";
scmd.CommandType = CommandType.StoredProcedure;
scmd.Connection = scon;
//3.打开连接
scon.Open();
//设置参数
scmd.Parameters.Add(new SqlParameter("@name", "Test"));
scmd.Parameters.Add("));
scmd.Parameters.Add());
SqlParameter parameters = new SqlParameter();
parameters.Value = ;
parameters.DbType = DbType.Int32;
parameters.ParameterName = "@age";
scmd.Parameters.Add(parameters);
//4执行命令
int id= (int)scmd.ExecuteScalar();
Console.WriteLine("你这次插入的数据的主键是{0}", id);
Console.ReadKey();
}
}
}
编码实现
程序运行的效果图:

注意:如果想要还原主键字段,可以使用truncate table 表名,把数据清空,然后执行的时候,就是从主键1开始的
ADO.NET---ExcuteScalar()方法复习的更多相关文章
- PHP面向对象之魔术方法复习
魔术方法复习 2014-9-2 10:08:00 NotePad++ By jiancaigege 飞鸿影~========================= 1.__construct() 构造方法 ...
- 使用相对路径导入ado库的方法
作者:朱金灿 来源:http://blog.csdn.net/clever101 常用的导入ado库的语句: #import "c:\program files\common files\s ...
- 个人常用jq方法复习
$("#elem").on({ mouseover:function(){}, mouseout:function(){}, }); $(ele).closest("di ...
- ADO.NET 学习笔记 入门教程
本文转载自:http://www.youarebug.com/forum.php?mod=viewthread&tid=57&page=1&extra=#pid63 这是本人在 ...
- ADO.net基础学习总结(二)
将连接字符串放入配置文件中 1.添加一个“应用程序配置文件:app.config” <?xml version="1.0" encoding="utf-8" ...
- ado.net的简单数据库操作(二)之封装SqlHelperl类
今天我书接上回,接着昨天的ado.net的数据库操作的相关知识来讲哈! 从上篇文章给出的实例来看,你一定会发现,操作数据库其实还挺麻烦的,就连一个最简单的数据库操作语句都要包括 定义数据库连接字符串. ...
- vc++用ADO方式连接oracle问题
今天装了个oracle客户端,准备写个访问远程oracle的程序.用的是vs2010,采用ADO的连接方法连接oracle,结果运行的时候总是报下面的错: 从提示可以看出是没有找到OraOLEDBup ...
- ADO.NET知识汇总
这又是一篇记录平常工作笔记的博客,无论是在排版还是解说上都不会有太多要求.同时这也是一篇不上博客园首页的博客,Just记录一些工作笔记. vSelect返回单个值 string connSQL = @ ...
- vc6.0 通过ADO(udl)连接sql 2008
转载声明:本文转自http://blog.sina.com.cn/s/blog_7328b9dd0100pkbw.html茗之的博客 首先声明:本文是针对vc与sql菜鸟的,高人请让路. 本文讲解 ...
随机推荐
- HTTP 错误 500.21 - Internal Server Error 处理程序“ExtensionlessUrlHandler-Integrated-4.0”在其模块列表中有一个错误模块“ManagedPipelineHandler”
导致这个错误出现的原因是因为.net Framework4.0没有注册 解决方法:打开运行命令行,运行下面的命令: C:\WINDOWS\Microsoft.NET\Framework\v4.0.30 ...
- How To Create a Personal Balance Sheet
Calculating your personal net worth is the best way to know exactly what your starting point is, in ...
- 提高 Android 代码质量的4个工具
在这篇文章中,我将通过不同的自动化工具如CheckStyle,FindBugs,PMD以及Android Lint来介绍(如何)提高你的安卓代码质量.通过自动化的方式检查你的代码非常有用,尤其当你在一 ...
- HBase修改压缩格式及Snappy压缩实测分享
一.要点 有关Snappy的相关介绍可参看Hadoop压缩-SNAPPY算法,如果想安装Snappy,可以参看Hadoop HBase 配置 安装 Snappy 终极教程. 1. HBase修改Tab ...
- Schema Workbench 开发mdx和模式文件
一.前言 安装了saiku之后,每次修改schema文件,非常耗时,每次都要经历若干步骤:修改xml.上传.重启才能生效,并且非常不利于学习和理解MDX和模式文件,踌躇之际,发现了这个工具,十分小巧方 ...
- 图解 & 深入浅出Java初始化与清理:构造器必知必会
Writer :BYSocket(泥沙砖瓦浆木匠) 微 博:BYSocket 豆 瓣:BYSocket FaceBook:BYSocket Twitter ...
- IIS7/IIS7.5 二级域名伪静态设置方法
转载地址:http://www.admin5.com/article/20120107/402582.shtml
- JAVA多线程编程之生产者消费者模式
Java中有一个BlockingQueue可以用来充当堵塞队列,下面是一个桌面搜索的设计 package net.jcip.examples; import java.io.File; import ...
- 【Java】深入理解ThreadLocal
一.前言 要理解ThreadLocal,首先必须理解线程安全.线程可以看做是一个具有一定独立功能的处理过程,它是比进程更细度的单位.当程序以单线程运行的时候,我们不需要考虑线程安全.然而当一个进程中包 ...
- 树莓派 LED+蜂鸣+声音传感器+红外模块组合打造声控/红外控制LED
昨天搞了控制LED,玩了第一个,剩下的就感觉很简单了,这里记录一下 先来几张照片 玩了蜂蜜模块才发现规律,一般这种模块,都会有三个针脚,VCC(3.3V或5V供电输出针脚).GNC(对应GPIO针脚的 ...