文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

ADO.NET如何使用DataAdapter类

2023-06-17 20:30

关注

这篇文章主要介绍ADO.NET如何使用DataAdapter类,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

ADO.NET使用还是比较常用的,于是我研究了一下ADO.NET,在这里拿出来和大家分享一下,希望对大家有用。说说关于ADO.NET使用DBCommand这个类,所有对数据库的操作都是通过它进行完成的。如果把DBConnection比作通路的话,那么DBCommand就是在这条通路上来回跑动的车辆。缺少了它,在程序中所有对数据库的操作无法传递给数据库服务器端。因此可以说,DBConnection和DBCommand组成ADO.NET的基础。在对DBCommand对象进行操作的时候,需要注意如下几点。

设置CommandText和CommandType属性,一般情况下是不需要设置CommandType属性,但是如果执行存储过程,则需要设置CommandType属性为StoredProcedure。建议多使用参数,而减少字符串的拼接,这样一是可以减少程序书写错误,而可以避免语句蛀虫。参数的使用可以如下:

SqlCommand myComm = new SqlCommand();  myComm.CommandText = “SELECT * FROM UserInfo WHERE UserName = @UserName ”;  myComm.Parameters.Add( “@UserName”, yourValue );

区分ExecuteNonQuery方法和ExecuteReader方法,前者是主要是处理非查询类型的语句,返回的个数是受影响的个数,但其对“INSERT”语句是不起任何作用的;而后者主要是处理查询语句,但是需要借助DataReader来辅助操作。***不要忘了在用完后,调用Dispose方法对DBCommand对象进行释放。而要想获得查询的记录集,仅仅靠DBCommand是无法完成的,因此要借助DataReader来获得所查询的记录。例如:

SqlCommand myComm = new SqlCommand();  myComm.CommandText = “SELECT * FROM UserInfo WHERE UserName = @UserName ”;  myComm.Parameters.Add( “@UserName”, yourValue );  SqlDataReader myReader = myComm.ExecuteReader();  while( myReader.Read() )  {  myReader.GetValue( index );// Get value through specific index  }  myReader.Close();  myComm.Dispose();

所以在DataReader中比较常见的两个方法,就是Read和GetValue,前者是判断是否读出记录,后者是获得记录中某个字段的值,其返回是object类型对象,需要进行类型转换才能得到想要得字段值。可惜的是,DataReader每次只能读出一行记录,因此在使用它的时候,查询结果要逐行读取,其间它对DBConnection是独享,即不能在此时刻用同一个DBConnection去做其它的数据库操作。

要提的一点是,在ADO.NET中提供了一个更好的、更方便的数据操作工具,即DataAdapter类。对于一个DataAdapter对象,可以设置四个DBCommand,分别是SelectCommand、InsertCommand、DeleteCommand、UpdateCommand。而这四个DBCommand并不需要全部初始化,主要是看程序的具体要求,如果只是用到查询方面,那么只需要设定一下SelectCommand即可,这和一般的DBCommand操作一样

对于DataAdapter操作返回的记录集,需要用DataSet来进行辅助操作,例如:

获得查询的记录集

DataAdapter.Fill( DataSet, “yourTableName” );// “yourTableName” is the name using in data set

更新数据库

DataAdapter.Update( DataSet, “yourTableName” );

此处要注意的是:首先DataSet要发生变化,如果和Fill之后一样,对数据库则没什么影响;再者要设置InsertCommand、DeleteCommand、UpdateCommand,如果不设置对应操作语句,则一样对数据库没任何影响。相对而言,DataAdapter效率要差一些,但是避免了一些操作,读取记录集,对获得记录数据进行类型转换等等。同时其对DBConnection的占有只是在对数据库操作的时候,操作完即立刻释放。因此,强烈建议多ADO.NET使用DataAdapter,而少ADO.NET使用DataReader。在文章的结尾,要说明的,以上所提到的只是数据库操作的虚类名,如果程序真正操作数据库,则要根据数据库的不同,选择不同子类来建立对象。

以上是“ADO.NET如何使用DataAdapter类”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯