C#操作Access数据库之SELECT操作浅析

C#操作Access数据库之SELECT操作是如何的呢,让我们开始讲解:

封丘网站建设公司成都创新互联公司,封丘网站设计制作,有大型网站制作公司丰富经验。已为封丘1000多家提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的封丘做网站的公司定做!

下面是我的自己在写测试程序的时候用到了,先列出来看看OleDbDataReader和OleDbDataAdapter是如何操作从数据库中选择记录的:

 
 
 
  1. //通过ID得到当前留言详细内容.通过STRING类型参数
  2. public Notebook getNoteFromID(string noteid)
  3. Notebook tempnote=new Notebook(); //定义返回值
  4. try //C#操作Access数据库之SELECT操作
  5. {
  6. OleDbConnection conn = getConn();
  7.  //getConn():得到连接对象
  8. string strCom = "Select * from notes where id=" + noteid ;
  9. OleDbCommand myCommand =new OleDbCommand(strCom,conn);
  10. conn.Open();
  11. OleDbDataReader reader; 
  12. reader =myCommand.ExecuteReader() ; 
  13. //执行command并得到相应的DataReader
  14. //下面把得到的值赋给tempnote对象
  15. if(reader.Read())
  16. {  //C#操作Access数据库之SELECT操作
  17. tempnote.id=(int)reader["id"];
  18. tempnote.title=reader["title"].ToString();
  19. tempnote.content=reader["content"].ToString();
  20. tempnote.author=reader["author"].ToString();
  21. tempnote.email=reader["email"].ToString();
  22. tempnote.http=reader["http"].ToString();
  23. tempnote.pic=reader["pic"].ToString();
  24. tempnote.hits=(int)reader["hits"];
  25. tempnote.posttime=(DateTime)reader["posttime"];
  26. }
  27. else //如没有该记录,则抛出一个错误!
  28. {
  29. throw(new Exception("当前没有该记录!"));
  30. }
  31. reader.Close();
  32. conn.Close();
  33. }
  34. catch(Exception e)
  35. {
  36. //throw(new Exception("数据库出错:" + e.Message)) ;
  37. }
  38. return(tempnote); //返回Databook对象
  39. } //C#操作Access数据库之SELECT操作

上面的程序就是通过OleDbDataReader来得到特定的记录的!其中用到的语句我单独写到下面:

 
 
 
  1. OleDbConnection conn = getConn();
  2.  //getConn():得到连接对象
  3. string strCom = "Select * from notes where id=" + noteid ; 
  4. //SQL语句
  5. OleDbCommand myCommand =new OleDbCommand(strCom,conn);
  6.  //建立OleDbCommand对象
  7. conn.Open(); //注意我在前面说的Open语句在这里使用到了!
  8. OleDbDataReader reader; 
  9. reader =myCommand.ExecuteReader() ;
  10.  //执行command并得到相应的结果

我在每句话后都加入了说明,其中OleDbConnection conn = getConn();就是通过我前面提到的getConn函数来得到数据库连接的,其他语句没有什么好说的,都很简单,就不多说了!

C#操作Access数据库之SELECT操作:再列一个通过OleDbDataAdapter来得到记录的例程:

 
 
 
  1. //Getlist():得到当前需要的留言列表
  2. public DataView getNoteList()
  3. DataView dataview;
  4. System.Data.DataSet mydataset; //定义DataSet
  5. try
  6. OleDbConnection conn = getConn(); //getConn():得到连接对象
  7. OleDbDataAdapter adapter = new OleDbDataAdapter();
  8. string sqlstr="select * from notes order by posttime desc";
  9. mydataset= new System.Data.DataSet();
  10. adapter.SelectCommand = new OleDbCommand(sqlstr, conn);
  11. adapter.Fill(mydataset,"notes"); 
  12. conn.Close();
  13. }  //C#操作Access数据库之SELECT操作
  14. catch(Exception e)
  15. {
  16. throw(new Exception("数据库出错:" + e.Message)) ;
  17. dataview = new DataView(mydataset.Tables["notes"]);
  18. return(dataview); 
  19. }

这个程序或许有些复杂,同样的,我还是先把那些关键语句列出,并说明:

 
 
 
  1. OleDbConnection conn = getConn(); 
  2. //通过函数getConn()得到连接对象
  3. OleDbDataAdapter adapter = new OleDbDataAdapter(); 
  4. //实例化OleDbDataAdapter对象
  5. string sqlstr="select * from notes order by posttime desc"; 
  6. //SQL语句
  7.  //C#操作Access数据库之SELECT操作
  8. mydataset= new System.Data.DataSet(); 
  9. //由于OleDbDataAdapter需要和DataSet结合使用,所以在这里定义了DataSet对象,
  10. //其实说OleDbDataAdapter复杂,
  11. //其实就是因为DataSet的缘故DataSet有些类似于ADO中的recordset 对象,
  12. //但功能远远超过了它,而且它和数据库是断开的,并能存放多个记录集!
  13. adapter.SelectCommand = new OleDbCommand(sqlstr, conn); 
  14. //设置命令为SelectCommand类型的
  15. adapter.Fill(mydataset,"notes");
  16.  //执行,并将结果添加到mydataset中的”notes”表中
  17. conn.Close(); //关闭连接!

在对上面的程序加一些补充说明,由于getNoteLista是得到一系列记录,并通过控件DataGrid来做分页显示的,所以我返回的是一个DataView类型的对象!

C#操作Access数据库之SELECT操作的基本内容就向你介绍到这里,希望对你了解和学习C#操作Access数据库之SELECT操作有所帮助。

当前标题:C#操作Access数据库之SELECT操作浅析
文章来源:http://www.shufengxianlan.com/qtweb/news7/133657.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联