zoukankan      html  css  js  c++  java
  • executereader与executescalar的区别

    引用

    柯 的 executereader与executescalar这2个有什么区别

    ExecuteReader:可以读一个表的记录,只能读不能写

    ExecuteScalar:只能读一条记录,一般用来判断数据库是否有数据等,只能读不能写

    ExecuteNonQuery:可以写以可以读,

     首先,我们知道这三个东东应该是ADO.NET中对数据库中操作的CMD,我们知道,如果我们
    要进行一个网让建设,必然在这个过程中,我们一定要进行与数据库的交互,我们要不断地
    进行数据库的读写,那么ExecuteNonQuery(),ExecuteReader()与ExecuteScalar()就是我们
    在对数据库进行操作时要用到的,下面我来依次认识一下:

        ExecuteNonQuery():这个东东可以让我们在更新数据库时不使用 DataSet 而使用
    ExecuteNonQuery 更改数据库中的数据。通过执行 UPDATE、INSERT 或 DELETE SQL语句就
    可以达到更改数据库中的数据目的。即使 ExecuteNonQuery 不返回任何行,映射到参数的输
    出参数或返回值仍然使用数据填充。但对于 UPDATE、INSERT 和 DELETE SQL语句,返回的
    值就是受ExecuteNonQuery()命令影响的行数。对其它类型的语句以及回退来说,返回的值
    都是 -1。

       ExecuteReader():我们通常在asp中用Recordset对象来从数据库中读出数据,并且用
    循环语句来一个一个的读出数据,但在我们的ADO.NET中,我们就是用DataReader 对象的
    ExecuteReader()方法来进行数据的列出,并且我们用这个ExecuteReader()方法来显示数据
    是最快的一种方法,因为当我们在用ExecuteReader()方法中的DataReader 对象来进行数据
    的在网站建设中显示时,他只可以一条一条向前读,不能返回,也就是像ASP中的ADO方法
    中的Recordset 对象的Movenext一样,他没有move -1这样的返回方法。

        ExecuteScalar():这种CMD相当于我们在ADO中用SQL语句中使用一些计算函数的功
    能一样,在这里我们只是返回所有影响的行数的第一行第一列数据,这样也就是相当于专业
    为我们的如:select count(*) from database的功能一样,我们可以用

    string sql="select * from  database"

    SqlCommand cmd=SqlCommand(sql,conn)

    int i=(int)cmd.ExecuteScalar()

    这样我们的局部变更i的值就是与上面我的功能一样.

        最后值得一说的是:这是出自我平时所用的时候的一些认识:那就是如果我们在进行数
    据操作时,如果没有数据可操作,那么我们只能使用ExecuteReader()这个CMD,而
    executeNoeQuery()与Executescalar()如果在没有数据的时候使用时,就会出错“对像没有
    实例化”的错误。所以我们在判断是否有数据时,只可以用ExecuteReader()中的REad()方
    法来检测。

  • 相关阅读:
    .NET微服务调查结果
    发布基于Orchard Core的友浩达科技官网
    Followme Devops实践之路
    积极参与开源项目,促进.NET Core生态社区发展
    Service Fabric 与 Ocelot 集成
    “.Net 社区大会”(dotnetConf) 2018 Day 1 主题演讲
    Project file is incomplete. Expected imports are missing 错误解决方案
    稳定工作和创业之间的抉择
    回顾4180天在腾讯使用C#的历程,开启新的征途
    ML-Framework:ML.NET 0.3 带来新组件
  • 原文地址:https://www.cnblogs.com/fat_li/p/1887533.html
Copyright © 2011-2022 走看看