zoukankan      html  css  js  c++  java
  • ADO.NET中的五大对象

    在ADO.NET中有五大对象

    对象:

    Connection:主要用来开启程序和数据库之间的连接,没有利用Connection对象连接数据库,是无法从数据库中取得数据的。Close()和Dispose()的区别就是Close以后还可以Open,但是Dispose是释放了连接,要操作数据库就要重新连接数据库。

    Command:主要用来对数据库发出一些指令,例如可以对数据库发出增删改查的指令,或者调用存在数据库中的存储过程等。这个对象是建立在Connection对象之上的,也就是Command对象需要连接到数据库之后才可以操作数据库中的数据。

    DataSet:这个对象可以视为一个暂存区(Cache),可以把从数据库中所查询到的数据保留起来,甚至可以将整个数据库显示出来,DataSet是放在内存中的,DataSet的能力不只是可以存储多个Table而已,还可以透过DataAdapter对象取得一些例如主键等的数据表结构,并可以记录数据表间的关联。DataSet对象可以说是ADO.Net中重量级的对象,这个对象架构在DataAdapter对象上,本身不具备和数据源沟通的能力;也就是说我们是将DataAdapter对象当作DataSet对象以及数据源间传输数据的桥梁。DataSet包含若干DataTable、DataTable包含若干DataRow。

    DataAdapter:主要是在数据源以及DataSet之间执行数据库传输工作,它可以透过Command对象下达命令后,然后将取得的数据通过DataAdapter对象调用Fill()方法填充到DataSet对象中。

    DataReader:当我们只需要循序的读取数据而不需要其他操作时,可以使用DataReader对象。DataReader对象只是一次一次向下循序读取数据源中的数据,这些数据是存在数据库服务器中的,而不是一次性加载到程序的内存中的,只能(通过游标)读取当前行的数据,而且这些数据是只读的,并不允许其他的操作。因为DataReader在读取数据的时候限制了每次只读取一行,而且只能只读,所以使用起来不但节省资源而且效率很高。使用DataReader对象除了效率较好之外,因为不用把数据全部传回,故可以降低网路的负载。

    ADO.NET主要分为:DataSet和.net frameword数据提供程序。

    command对象的三个方法:ExecuteNonQuery(),ExecuteReader(),ExecuteScalar();

    ExecuteNonQuery()此方法用来执行增加(insert),删除(delete),修改(update)数据用,返回被sql语句影响的行数。在存储过程中遇到set nocount on时返回默认值,修改表中有触发器时,返回结果合实际结不同。

    ExecuteReader()此方法用来读取表中数据,仅向前,速度比较快(相对于dataAdapter)。

    ExecuteScalar()此方法用来读取select语句中返回的第一行第一列的值,返回值是object类型,注意思数据类型转换。

    dataAdapter对象的Fill()方法用来填充数据集中的数据,Update()方法可以更新数据集中被修改的数据到数据库中。在调用Update()前先指定DbCommandBuilder,可以自动生dataAdapter对象的InsertCommand,UpdateCommand,DeleteCommand属性等。在生成这些Command对象前有一事值得注意,也就是当数据集中有新增数据时会生成InsertCommand,否则则不成生此对象。当数据集内数据发生更改时,此时会生成UpdateCommand,如果没有修改结果不生成此对象,当数据集内有删除数据时,生成DeleteCommand,如果没有删除数据不生成此对象。当数据集内没有数据发生改变时,此时调用Update()返回值为0,如果修改,有几行记录修改则返回几。

    这五大内置对象为.net操作数据库必会的五大对象,缺一不可。

  • 相关阅读:
    spring boot + swagger2
    itext7 html转pdf实现
    shell脚本学习
    观察者模式
    sql mode 问题及解决 错误代码:1055 this is incompatible with sql_mode=only_full_group_by
    学生报数算法实现
    git reset 版本回退操作
    struts2方法无法映射问题:There is no Action mapped for namespace [/] and action name [m_hi] associated with context path []
    Vue日历组件的功能
    vue-router 在新窗口打开页面的功能
  • 原文地址:https://www.cnblogs.com/codedisco/p/12714283.html
Copyright © 2011-2022 走看看