C# 操作ACCESS数据库
合集下载
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
我在每句话后都加入了说明,其中 OleDbConnection conn = getConn();就是通过我前面提到的 getConn 函数来得到数据库连接 的,其他语句没有什么好说的,都很简单,就不多说了!
我再列一个通过 OleDbDataAdapter 来得到记录的例程:
//Getlist():得到当前需要的留言列表 public DataView getNoteList() { DataView dataview; System.Data.DataSet mydataset; //定义 DataSet
相信只要使用过 ADO 的朋友应该都可以看懂的!我们先定义一个 String 类型的变量,其中存放了我们连接数据库的连接字符串,然后 在定义一个 System.Data.OleDb.OleDbConnection 类型的对象并 实例化,最后返回这个对象!需要说明一下的是,我并没有把语 句:tempconn.Open();放到这个函数中,原因我我稍后在说明,这里 只是先提醒一下!
System.Data.OleDb.OleDbDataAdapter:可以直接和 DataSet 联系,并操作数据源的,它的功能相对强大一些,因此也比较耗系统资 源!
System.Data.OleDb.OleDbDataReader:则有些类似于 ADO 中的 哪个只读向前的记录集, 它最常用在只需要依次读取并显示数据的时候, 相比 System.Data.OleDb.OleDbDataAdapter 来说, 他耗用的系统 资源要小!其实,OleDbDataReader 能实现的功能, OleDbDataAdapter 都可以实现,不过从资源使用率的角度考虑我们 应该尽量使用前者!但有些功能,却是必须使用 OleDbDataAdapter 才可以实现的!
mydataset= new System.Data.DataSet(); //由于 OleDbDataAdapter 需要和 DataSet 结合使用,所以在这里定义了
DataSet 对象,其实说 OleDbDataAdapter 复杂,其实就是因为 DataSet 的缘故 DataSet 有些类似于 ADO 中的 recordset 对象, 但 功能远远超过了它,而且它和数据库是断开的,并能存放多个记录集!
பைடு நூலகம்
通过上面的函数,我们就已经得到了类似于 ADO 中的连接对象 Connection 了!下面的就是具体操作数据库了!
在具体讲操作前,我认为有必要先认识一下下面的两个类: System.Data.OleDb.OleDbDataAdapter System.Data.OleDb.OleDbDataReader
C# 操作 ACCESS 数据库
在 BETA2 中,。NET 提供了
在 BETA2 中,。NET 提供了以下的 NAMESPACE: System.Data Namespace System.Data.OleDb (和 BETA1 中已经不同了, 所以如果拿 BETA1 中的程序到 BETA2 中来运行肯定不可以的)
try { OleDbConnection conn = getConn(); //getConn():得到连接对象
OleDbDataAdapter adapter = new OleDbDataAdapter(); string sqlstr="select * from notes order by posttime desc"; mydataset= new System.Data.DataSet(); adapter.SelectCommand = new OleDbCommand(sqlstr, conn); adapter.Fill(mydataset,"notes"); conn.Close(); } catch(Exception e) { throw(new Exception("数据库出错:" + e.Message)) ; } dataview = new DataView(mydataset.Tables["notes"]); return(dataview); }
//下面把得到的值赋给 tempnote 对象 if(reader.Read()) { tempnote.id=(int)reader["id"]; tempnote.title=reader["title"].ToString(); tempnote.content=reader["content"].ToString(); tempnote.author=reader["author"].ToString(); tempnote.email=reader["email"].ToString(); tempnote.http=reader["http"].ToString(); tempnote.pic=reader["pic"].ToString(); tempnote.hits=(int)reader["hits"]; tempnote.posttime=(DateTime)reader["posttime"]; } else //如没有该记录,则抛出一个错误! { throw(new Exception("当前没有该记录!")); }
reader.Close(); conn.Close(); } catch(Exception e) { //throw(new Exception("数据库出错:" + e.Message)) ; } return(tempnote); //返回 Databook 对象 }
上面的程序就是通过 OleDbDataReader 来得到特定的记录的!其中 用到的语句我单独写到下面: OleDbConnection conn = getConn(); //getConn():得到连接对
* SELECT 操作! 下面是我的自己在写测试程序的时候用到了,先列出来看看 OleDbDataReader 和 OleDbDataAdapter 是如何操作从数据库中选 择记录的:
//通过 ID 得到当前留言详细内容.通过 STRING 类型参数 public Notebook getNoteFromID(string noteid) { Notebook tempnote=new Notebook(); //定义返回值
我先写出我自己使用的程序:
using System.Data using System.Data.OleDb
public OleDbConnection getConn() {
string connstr="Provider=Microsoft.Jet.OLEDB.4.0 ;Data Source=F:\\web\\notesb ook\\class\\leavenotes.mdb"; OleDbConnection tempconn= new OleDbConnection(connstr); return(tempconn); }
try { OleDbConnection conn = getConn(); //getConn():得到连接对象 string strCom = "Select * from notes where id=" + noteid ; OleDbCommand myCommand =new OleDbCommand(strCom,conn); conn.Open(); OleDbDataReader reader; reader =myCommand.ExecuteReader() ; //执行 command 并得到相应的 DataReader
adapter.SelectCommand = new OleDbCommand(sqlstr, conn); //设置命令为 SelectCommand 类型的
adapter.Fill(mydataset,"notes"); //执行,并将结果添加到 mydataset 中的”notes”表中 conn.Close(); //关闭连接!
//确定我们需要执行的 SQL 语句,本处是 UPDATE 语句! sqlstr = "UPDATE notes SET "; sqlstr += "title='" + note.title + "',"; sqlstr += "content='" + DealString(note.content) +"',"; sqlstr += "author='" + note.author + "',"; sqlstr += "email='" +note.email +"',"; sqlstr += "http='" +note.http +"'"; //sqlstr += "pic='" +note.pic +"'"; sqlstr += " where id=" + note.id;
在对上面的程序加一些补充说明,由于 getNoteLista 是得到一系列记 录,并通过控件 DataGrid 来做分页显示的,所以我返回的是一个 DataView 类型的对象! ---------------------------------------上次说了如何在 ADO。NET 中执行“SELECT”语句,这次我们看看, 如何执行“DELETE、UPDATE、INSERT”等语句。
我们这次同样通过例子来看,其中我们用到了 System.Data.OleDb.OleDbCommand 类,其实,我们在前面执行 SELECT 的时候也用到了!
下面我写出我的程序:
//修改留言本中特定的数据 public Boolean UpdateNote(Notebook note) { Boolean tempvalue=false; string sqlstr=""; //当时在这里定义,是为了在出现异常的时候看看我的 SQL 语句是否正确 try { //用到了我前面写的那个得到数据库连接的函数 OleDbConnection conn = getConn(); //getConn():得到连接对象, conn.Open();
如果想讲清楚这些东西,我不认为是我可以作到的,所以我想通过一些 具体的程序来把我们对数据库的最基本的操作(SELECT、UPDATE、 DELETE、INSERT 等)演示一下,其他的还是需要朋友们在学习过程 中来慢慢体会了!
要想操作一个数据库, 不论是那种操作, 首先要做的肯定是打开数据库, 下面我们以 ACCESS 数据库来做例子说明如何打开一个数据库连接! 在这里我们需要用到的是:System.Data.OleDb.OleDbConnection 类!(如果操作 SQL 数据库,我们最好使用 System.Data.SqlClient.SqlConnection 类)
这个程序或许有些复杂,同样的,我还是先把那些关键语句列出,并说 明:
OleDbConnection conn = getConn(); //通过函数 getConn()得到 连接对象 OleDbDataAdapter adapter = new OleDbDataAdapter(); //实 例化 OleDbDataAdapter 对象 string sqlstr="select * from notes order by posttime desc"; //SQL 语句
象 string strCom = "Select * from notes where id=" + noteid ; //SQL 语句 OleDbCommand myCommand =new OleDbCommand(strCom,conn); //建立 OleDbCommand 对象 conn.Open(); //注意我在前面说的 Open 语句在这里使用到了! OleDbDataReader reader; reader =myCommand.ExecuteReader() ; //执行 command 并 得到相应的结果