



下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、c#操作Access数据库的方法大全using System.Data.OleDb; using System.Data;连接字符串:String connectionString = Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb;建立连接:OleDbConnection connection = new OleDbConnection(connectionString);使用OleDbCommand类来执行Sql语句:OleDbCommand cmd = new OleDbCommand(sql, connection);c
2、onnection.Open();cmd.ExecuteNonQuery();1.创建mdb库,例程如下:需要注意的是:参数mdbPath是mdb的完整路径(不包含表的名称)。例如:D:test.mdb /创建mdb public static bool CreateMDBDataBase(string mdbPath) try ADOX.CatalogClass cat = new ADOX.CatalogClass(); cat.Create(Provider=Microsoft.Jet.OLEDB.4.0;Data Source= + mdbPath + ;); cat = null;
3、return true; catch return false; 2.创建具体的表,例程如下:通常一个mdb的可以包含n个表。下面的程序主要是创建一个table。 /新建mdb的表 /mdbHead是一个ArrayList,存储的是table表中的具体列名。 public static bool CreateMDBTable(string mdbPath,string tableName, ArrayList mdbHead) try ADOX.CatalogClass cat = new ADOX.CatalogClass(); string sAccessConnection = Prov
4、ider=Microsoft.Jet.OLEDB.4.0;Data Source= + mdbPath; ADODB.Connection cn = new ADODB.Connection(); cn.Open(sAccessConnection, null, null, -1); cat.ActiveConnection = cn; /新建一个表 ADOX.TableClass tbl = new ADOX.TableClass(); tbl.ParentCatalog = cat; tbl.Name = tableName; int size = mdbHead.Count; for (
5、int i = 0; i size; i+) /增加一个文本字段 ADOX.ColumnClass col2 = new ADOX.ColumnClass(); col2.ParentCatalog = cat; col2.Name = mdbHeadi.ToString();/列的名称 col2.PropertiesJet OLEDB:Allow Zero Length.Value = false; tbl.Columns.Append(col2, ADOX.DataTypeEnum.adVarWChar, 500); cat.Tables.Append(tbl); /这句把表加入数据库(非
6、常重要) tbl = null; cat = null; cn.Close(); return true; catch return false; 3.读取mdb内容(完全读取),例程如下:本例程返回的是一个DataTable,如需其他格式可以自行转换。 / 读取mdb数据 public static DataTable ReadAllData(string tableName, string mdbPath,ref bool success) DataTable dt = new DataTable(); try DataRow dr; /1、建立连接 string strConn = Pr
7、ovider=Microsoft.Jet.OLEDB.4.0;Data Source= + mdbPath + ;Jet OLEDB:Database Password=haoren; OleDbConnection odcConnection = new OleDbConnection(strConn); /2、打开连接 odcConnection.Open(); /建立SQL查询 OleDbCommand odCommand = odcConnection.CreateCommand(); /3、输入查询语句 odCommand.CommandText = select * from +
8、tableName; /建立读取 OleDbDataReader odrReader = odCommand.ExecuteReader(); /查询并显示数据 int size = odrReader.FieldCount; for (int i = 0; i size; i+) DataColumn dc; dc = new DataColumn(odrReader.GetName(i); dt.Columns.Add(dc); while (odrReader.Read() dr = dt.NewRow(); for (int i = 0; i size; i+) drodrReader
9、.GetName(i) = odrReaderodrReader.GetName(i).ToString(); dt.Rows.Add(dr); /关闭连接 odrReader.Close(); odcConnection.Close(); success = true; return dt; catch success = false; return dt; 4.读取mdb内容(按列读取),例程如下:columns数组存储的是你要查询的列名称(必须确保mdb表中存在你要的列) / 读取mdb数据 public static DataTable ReadDataByColumns(string
10、 mdbPaht,string tableName, string columns, ref bool success) DataTable dt = new DataTable(); try DataRow dr; /1、建立连接 string strConn = Provider=Microsoft.Jet.OLEDB.4.0;Data Source= + mdbPath + ;Jet OLEDB:Database Password=haoren; OleDbConnection odcConnection = new OleDbConnection(strConn); /2、打开连接 o
11、dcConnection.Open(); /建立SQL查询 OleDbCommand odCommand = odcConnection.CreateCommand(); /3、输入查询语句 string strColumn = ; for (int i = 0; i columns.Length; i+) strColumn += columnsi.ToString() + ,; strColumn = strColumn.TrimEnd(,); odCommand.CommandText = select +strColumn+ from + tableName; /建立读取 OleDbDataReader odrReader = odCommand.ExecuteReader(); /查询并显示数据 int size = odrReader.FieldCount; for (int i = 0; i size; i+) DataColumn dc; dc = new DataColumn(odrReader.GetName(i); dt.Columns.Add(dc); while (odrReader.Read() dr = dt.NewRow(); for (int i = 0; i size; i+) drodrR
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025内蒙古额尔古纳市第一中学人才引进(第二号)考前自测高频考点模拟试题及答案详解(各地真题)
- 2025年芜湖市残疾人综合服务中心编外工作人员招聘2人模拟试卷含答案详解
- 2025昆明市禄劝县教育体育局所属事业单位面向县内学校选调人员(4人)模拟试卷及答案详解(易错题)
- 2025年山东文旅集团科技发展有限公司招聘考前自测高频考点模拟试题及完整答案详解
- 2025年河北地质大学选聘工作人员85名模拟试卷及参考答案详解一套
- 2025辽宁沈阳盛京资产管理集团有限公司所属子公司沈阳中城天玺不动产有限公司招聘1人考前自测高频考点模拟试题及1套参考答案详解
- 2025南昌市西湖区疾病预防控制中心招聘工作人员1人考前自测高频考点模拟试题有完整答案详解
- 2025年甘肃省卫生健康委系统招聘工作人员51人模拟试卷完整答案详解
- 2025年临沂市农业学校公开招聘教师(8名)模拟试卷附答案详解(突破训练)
- 2025广西卫生职业技术学院招聘高层次人才22人考前自测高频考点模拟试题及答案详解(历年真题)
- 新版中华民族共同体概论课件第八讲共奉中国与中华民族内聚发展(辽宋夏金时期)-2025年版
- 2025-2030儿童专注力训练行业市场需求与发展策略分析报告
- 反洗钱系统培训
- 《军品价格管理办法》
- 广东省中山市华辰实验中学2025-2026学年高三上学期开学考英语试题(含答案)
- 基孔肯雅热主题班会课件
- 麻醉恢复室护理要点
- 心力衰竭的全程管理
- 初中英语英语3500个单词分类大全
- 数学评比活动方案
- 三年级上册《快乐读书吧》阅读练习题
评论
0/150
提交评论