用C#动态创建Access数据库

转载 2007年10月12日 19:47:00

记得以前要动态的创建Access数据库的mdb文件都是采用DAO,用VC开发,一大堆的API,很是麻烦。现在好像也鲜有人提起DAO。其实动态的创建mdb数据的最简单的方法还是ADOX。
      用ADOX创建access数据库方法很简单,只需要new一个Catalog对象,然后调用它的Create方法就可以了,如下:

 

ADOX.Catalog catalog = new Catalog();
catalog.Create(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:/test.mdb;Jet OLEDB:Engine Type=5");

  仅仅两行代码就搞定了。下来我主要介绍一下在c#中的实现细节。首先你要添加引用,在“Add reference”对话框里切换到Com页面,选择“Microsoft ADO Ext. 2.8 for DDL and Security”,然后点击OK。在文件的开头using ADOX名字空间。然后添加如上面所示的代码就可以成功的创建Access 数据库了,代码如下:

using System;
using System.Collections.Generic;
using System.Text;
using ADOX;

namespace testADOX
...{
    
class Program
    
...{
        
static void Main(string[] args)
        
...{
            ADOX.Catalog catalog 
= new Catalog();
            catalog.Create(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:/test.mdb;Jet OLEDB:Engine Type=5");
        }

    }

}

创建了数据库文件是没有实际用处的,我们还要创建表。在创建表之前,我们必须连接目标数据库,用来连接数据的桥梁居然是ADO的Connection对象,所以我们不得不再次添加对ADO的应用,在添加引用对话框中切换到Com页面,选择“Microsoft ActiveX Data Objects 2.8 Library”,然后点击OK。下边是创建表的完整代码:
using System;
using System.Collections.Generic;
using System.Text;
using ADOX;

namespace testADOX
...{
    
class Program
    
...{
        
static void Main(string[] args)
        
...{
            ADOX.Catalog catalog 
= new Catalog();
            catalog.Create(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:/test.mdb;Jet OLEDB:Engine Type=5");

            ADODB.Connection cn 
= new ADODB.Connection();
            
            cn.Open(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:/test.mdb"nullnull-1);
            catalog.ActiveConnection 
= cn;

            ADOX.Table table 
= new ADOX.Table();
            table.Name 
= "FirstTable";

            ADOX.Column column 
= new ADOX.Column();
            column.ParentCatalog 
= catalog;
            column.Name 
= "RecordId";
            column.Type 
= DataTypeEnum.adInteger;
            column.DefinedSize 
= 9;
            column.Properties[
"AutoIncrement"].Value = true;
            table.Columns.Append(column, DataTypeEnum.adInteger, 
9);
            table.Keys.Append(
"FirstTablePrimaryKey", KeyTypeEnum.adKeyPrimary, column, nullnull);
            table.Columns.Append(
"CustomerName", DataTypeEnum.adVarWChar, 50);
            table.Columns.Append(
"Age", DataTypeEnum.adInteger, 9);
            table.Columns.Append(
"Birthday", DataTypeEnum.adDate, 0);
            catalog.Tables.Append(table);
         
            cn.Close();
        }

    }

}

 

用C#动态创建Access数据库

记得以前要动态的创建Access数据库的mdb文件都是采用DAO,用VC开发,一大堆的API,很是麻烦。现在好像也鲜有人提起DAO。其实动态的创建mdb数据的最简单的方法还是ADOX。       ...
  • hpnets
  • hpnets
  • 2016年08月31日 15:36
  • 1403

C#动态创建Access数据库及表的方法

本文实例讲述了C#动态创建Access数据库及表的方法。分享给大家供大家参考。 具体实现方法如下: //添加两个com组件引用 //Microsoft ADO Ext. 2.8 for D...
  • u011981242
  • u011981242
  • 2016年03月06日 23:00
  • 310

C#动态创建及连接ACCESS数据库的详细步骤

连接ACCESS数据库的详细步骤 一、建立FORM窗体,加一个按钮控件,加一个DATAGRIDVIEW控件。 二、双击FORM,加入命名空间using System.Data.OleDb;   ...
  • Goldxwang
  • Goldxwang
  • 2016年10月25日 08:36
  • 3017

用C#动态创建Access数据库

记得以前要动态的创建Access数据库的mdb文件都是采用DAO,用VC开发,一大堆的API,很是麻烦。现在好像也鲜有人提起DAO。其实动态的创建mdb数据的最简单的方法还是ADOX。       用...
  • qq_23992597
  • qq_23992597
  • 2016年05月11日 20:22
  • 571

基于C#的Access数据库的界面登陆_初体验数据库

在学习C#一小段时间后,网上逛发现对于C#这类界面开发,如果要做一个好一点的应用,不用数据库基本上不可能了。以前懒得学,都是用文件方式存储,然后再程序初始化的时候读出,并沾沾自喜的说,其实这样甚至在不...
  • FrankArmageddon
  • FrankArmageddon
  • 2014年01月12日 20:48
  • 1797

c# 操作ACCESS数据库

c# 简单操作ACCESS
  • nanxizhu
  • nanxizhu
  • 2014年11月06日 20:10
  • 2219

C#access数据库查询操作(一)

数据库有增,删,改,查等操作,但在实际数据库的应用过程中,查询实际上是应用的最多的一种对数据库的操作方式。 1.首先要说一个问题就是,在数据库的定义过程中,表里的字段的数据类型强烈建议按照数据类型定义...
  • pengshupan
  • pengshupan
  • 2016年04月20日 17:17
  • 4445

C#操作Access数据库步骤

本教程介绍了如何通过ADO.NET的OleDb相关类来操作Access数据库的相关步骤。 1     软件环境 开发平台:Microsoft Visual Studio 2010 数据库:Mic...
  • zhouxy0901
  • zhouxy0901
  • 2014年10月10日 20:13
  • 4438

C#连接ACCESS数据库的详细步骤!

一、建立FORM窗体,加一个按钮控件,加一个DATAGRIDVIEW控件。 二、双击FORM,加入命名空间using System.Data.OleDb;        双击按钮,进入按钮代码,写...
  • qingfeng45697
  • qingfeng45697
  • 2015年08月21日 15:21
  • 2966

C#访问Access数据库的数据库操作类

最近做了一些关于Access数据库的应用开发,其中涉及了对Access数据库的访问,现在将我们自己用到的几个基类贴出来给 大家看看,由于涉及功能并不多,其中有些也是借鉴了他人的代码,功能也比较简单,...
  • weizhiai12
  • weizhiai12
  • 2015年04月15日 16:14
  • 697
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用C#动态创建Access数据库
举报原因:
原因补充:

(最多只允许输入30个字)