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()方法复习的更多相关文章

  1. PHP面向对象之魔术方法复习

    魔术方法复习 2014-9-2 10:08:00 NotePad++ By jiancaigege 飞鸿影~========================= 1.__construct() 构造方法 ...

  2. 使用相对路径导入ado库的方法

    作者:朱金灿 来源:http://blog.csdn.net/clever101 常用的导入ado库的语句: #import "c:\program files\common files\s ...

  3. 个人常用jq方法复习

    $("#elem").on({ mouseover:function(){}, mouseout:function(){}, }); $(ele).closest("di ...

  4. ADO.NET 学习笔记 入门教程

    本文转载自:http://www.youarebug.com/forum.php?mod=viewthread&tid=57&page=1&extra=#pid63 这是本人在 ...

  5. ADO.net基础学习总结(二)

    将连接字符串放入配置文件中 1.添加一个“应用程序配置文件:app.config” <?xml version="1.0" encoding="utf-8" ...

  6. ado.net的简单数据库操作(二)之封装SqlHelperl类

    今天我书接上回,接着昨天的ado.net的数据库操作的相关知识来讲哈! 从上篇文章给出的实例来看,你一定会发现,操作数据库其实还挺麻烦的,就连一个最简单的数据库操作语句都要包括 定义数据库连接字符串. ...

  7. vc++用ADO方式连接oracle问题

    今天装了个oracle客户端,准备写个访问远程oracle的程序.用的是vs2010,采用ADO的连接方法连接oracle,结果运行的时候总是报下面的错: 从提示可以看出是没有找到OraOLEDBup ...

  8. ADO.NET知识汇总

    这又是一篇记录平常工作笔记的博客,无论是在排版还是解说上都不会有太多要求.同时这也是一篇不上博客园首页的博客,Just记录一些工作笔记. vSelect返回单个值 string connSQL = @ ...

  9. vc6.0 通过ADO(udl)连接sql 2008

    转载声明:本文转自http://blog.sina.com.cn/s/blog_7328b9dd0100pkbw.html茗之的博客   首先声明:本文是针对vc与sql菜鸟的,高人请让路. 本文讲解 ...

随机推荐

  1. 解决 NDP40-KB2468871不能安装

    新机子 成功装了vs2010,然后装sql2012提示让装vs2012sp1,下载了sp1,装的时候,装到最后一个包NDP40-KB2468871的时候报错了 KB2468871安装失败 错误: Ex ...

  2. [转] The program can't start because api-ms-win-crt-runtime-l1-1-0.dll is missing

    https://www.smartftp.com/support/kb/the-program-cant-start-because-api-ms-win-crt-runtime-l1-1-0dll- ...

  3. 倒计时,js

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  4. iOS常用宏 定义

    总结了iOS开发过程中的一些常用宏,以后会陆陆续续添加进来. 字符串是否为空 1   #define kStringIsEmpty(str) ([str isKindOfClass:[NSNull c ...

  5. Mesos源码分析

    Mesos源码分析(1): Mesos的启动过程总论 Mesos源码分析(2): Mesos Master的启动之一 Mesos源码分析(3): Mesos Master的启动之二 Mesos源码分析 ...

  6. Spark源码系列(二)RDD详解

    1.什么是RDD? 上一章讲了Spark提交作业的过程,这一章我们要讲RDD.简单的讲,RDD就是Spark的input,知道input是啥吧,就是输入的数据. RDD的全名是Resilient Di ...

  7. 国行手机安装GOOGLE PLAY

    原文地址:http://blog.sina.com.cn/s/blog_68cff87b0101a96k.html 相信国行的手机都是没有google Play 功能的吧,相比其它国外的手机,功能上逊 ...

  8. C# 开发者代码审查清单【转】

    这是为C#开发者准备的通用性代码审查清单,可以当做开发过程中的参考.这是为了确保在编码过程中,大部分通用编码指导原则都能注意到.对于新手和缺乏经验(0到3年工作经验)的开发者,参考这份清单编码会很帮助 ...

  9. MemCached用法

    所需要的jar包: com.danga.MemCached.MemCachedClient com.danga.MemCached.SockIOPool 自行下载/** * 缓存服务器集群,提供缓存连 ...

  10. 安卓开发笔记——自定义HorizontalScrollView控件(实现QQ5.0侧滑效果)

    对于滑动菜单栏SlidingMenu,大家应该都不陌生,在市场上的一些APP应用里经常可以见到,比如人人网,FaceBook等. 前段时间QQ5.0版本出来后也采用了这种设计风格:(下面是效果图) 之 ...