首页 数据库 mysql教程 C#操作Access数据库,收集了3篇经典文章

C#操作Access数据库,收集了3篇经典文章

Jun 07, 2016 pm 03:38 PM
access 导言 操作 数据库 文章 经典

【导言】因为开发制作一个小工具数据转移工具,需要用C#操作Access数据库。所以上网搜索了一下,有三篇文章内容比较好,特收录如下。 另有一份大礼送给网友:《ADO 程序员参考》 另一个链接:CSDN下载-ADO程序员参考中文版 一、创建数据库的基本方法: 原作

【导言】因为开发制作一个小工具“数据转移工具”,需要用C#操作Access数据库。所以上网搜索了一下,有三篇文章内容比较好,特收录如下。

另有一份大礼送给网友:《ADO 程序员参考》 

 另一个链接:CSDN下载-ADO程序员参考中文版

 

一、创建数据库的基本方法:

原作者迭失

microsoft ado ext.2.8
 
我想利用C#创建一个ACCESS数据库文件(A.mdb)。请问用什么办法可以实现。
A.mdb文件是原来没有的,程序需要创建一个然后往里面写数据!

1.
※新建工程
※进入解决方案->引用->添加引用

->选择-> OK
※编码
//命令行工程代码如下
using System;
using ADOX;
namespace ConsoleApplication1
{
class Class1
{
[STAThread]
static void Main(string[] args)
{
ADOX.CatalogClass cat = new ADOX.CatalogClass();
cat.Create("Provider=Microsoft.Jet.OLEDB.4.0;" +
"Data Source=D:\\AccessDB\\NewMDB.mdb;" +
"Jet OLEDB:Engine Type=5");
Console.WriteLine("Database Created Successfully");
cat = null;
}
}
}
//asp.net代码如下
private void Page_Load(object sender, System.EventArgs e)
{
ADOX.CatalogClass cat = new ADOX.CatalogClass();
cat.Create("Provider=Microsoft.Jet.OLEDB.4.0;" +
"Data Source=C://database//NewMDB.mdb;" +
"Jet OLEDB:Engine Type=5");
cat = null;
Response.Write("OK");
2.用sqlserver 的代码如下
SqlConnection conn=new SqlConnection("Server=lemoncat007;Uid=sa;Pwd=gtt");
conn.Open();
SqlCommand cmd=new SqlCommand("create database test",conn);
cmd.ExecuteNonQuery();
3 也可以创建一个Procedure 将创建数据库的语句写到里面然后执行
 

二、创建数据库,并且添表和添加字段

原文《用C#动态创建Access数据库》

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

C#操作Access数据库,收集了3篇经典文章ADOX.Catalog catalog = new Catalog();
C#操作Access数据库,收集了3篇经典文章catalog.Create(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\test.mdb;Jet OLEDB:Engine Type=5");
C#操作Access数据库,收集了3篇经典文章


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

C#操作Access数据库,收集了3篇经典文章using System;
C#操作Access数据库,收集了3篇经典文章
using System.Collections.Generic;
C#操作Access数据库,收集了3篇经典文章
using System.Text;
C#操作Access数据库,收集了3篇经典文章
using ADOX;
C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章
namespace testADOX
C#操作Access数据库,收集了3篇经典文章C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章{
C#操作Access数据库,收集了3篇经典文章    
class Program
C#操作Access数据库,收集了3篇经典文章C#操作Access数据库,收集了3篇经典文章    
C#操作Access数据库,收集了3篇经典文章{
C#操作Access数据库,收集了3篇经典文章        
static void Main(string[] args)
C#操作Access数据库,收集了3篇经典文章C#操作Access数据库,收集了3篇经典文章        
C#操作Access数据库,收集了3篇经典文章{
C#操作Access数据库,收集了3篇经典文章            ADOX.Catalog catalog 
= new Catalog();
C#操作Access数据库,收集了3篇经典文章            catalog.Create(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\test.mdb;Jet OLEDB:Engine Type=5");
C#操作Access数据库,收集了3篇经典文章        }

C#操作Access数据库,收集了3篇经典文章    }

C#操作Access数据库,收集了3篇经典文章}

C#操作Access数据库,收集了3篇经典文章


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

C#操作Access数据库,收集了3篇经典文章using System;
C#操作Access数据库,收集了3篇经典文章
using System.Collections.Generic;
C#操作Access数据库,收集了3篇经典文章
using System.Text;
C#操作Access数据库,收集了3篇经典文章
using ADOX;
C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章
namespace testADOX
C#操作Access数据库,收集了3篇经典文章C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章{
C#操作Access数据库,收集了3篇经典文章    
class Program
C#操作Access数据库,收集了3篇经典文章C#操作Access数据库,收集了3篇经典文章    
C#操作Access数据库,收集了3篇经典文章{
C#操作Access数据库,收集了3篇经典文章        
static void Main(string[] args)
C#操作Access数据库,收集了3篇经典文章C#操作Access数据库,收集了3篇经典文章        
C#操作Access数据库,收集了3篇经典文章{
C#操作Access数据库,收集了3篇经典文章            ADOX.Catalog catalog 
= new Catalog();
C#操作Access数据库,收集了3篇经典文章            catalog.Create(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\test.mdb;Jet OLEDB:Engine Type=5");
C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章            ADODB.Connection cn 
= new ADODB.Connection();
C#操作Access数据库,收集了3篇经典文章            
C#操作Access数据库,收集了3篇经典文章            cn.Open(
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\test.mdb"nullnull-1);
C#操作Access数据库,收集了3篇经典文章            catalog.ActiveConnection 
= cn;
C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章            ADOX.Table table 
= new ADOX.Table();
C#操作Access数据库,收集了3篇经典文章            table.Name 
= "FirstTable";
C#操作Access数据库,收集了3篇经典文章
C#操作Access数据库,收集了3篇经典文章            ADOX.Column column 
= new ADOX.Column();
C#操作Access数据库,收集了3篇经典文章            column.ParentCatalog 
= catalog;
C#操作Access数据库,收集了3篇经典文章            column.Name 
= "RecordId";
C#操作Access数据库,收集了3篇经典文章            column.Type 
= DataTypeEnum.adInteger;
C#操作Access数据库,收集了3篇经典文章            column.DefinedSize 
= 9;
C#操作Access数据库,收集了3篇经典文章            column.Properties[
"AutoIncrement"].Value = true;
C#操作Access数据库,收集了3篇经典文章            table.Columns.Append(column, DataTypeEnum.adInteger, 
9);
C#操作Access数据库,收集了3篇经典文章            table.Keys.Append(
"FirstTablePrimaryKey", KeyTypeEnum.adKeyPrimary, column, nullnull);
C#操作Access数据库,收集了3篇经典文章            table.Columns.Append(
"CustomerName", DataTypeEnum.adVarWChar, 50);
C#操作Access数据库,收集了3篇经典文章            table.Columns.Append(
"Age", DataTypeEnum.adInteger, 9);
C#操作Access数据库,收集了3篇经典文章            table.Columns.Append(
"Birthday", DataTypeEnum.adDate, 0);
C#操作Access数据库,收集了3篇经典文章            catalog.Tables.Append(table);
C#操作Access数据库,收集了3篇经典文章         
C#操作Access数据库,收集了3篇经典文章            cn.Close();
C#操作Access数据库,收集了3篇经典文章        }

C#操作Access数据库,收集了3篇经典文章    }

C#操作Access数据库,收集了3篇经典文章}

C#操作Access数据库,收集了3篇经典文章

      上面的代码中,创建了一个名为FirstTable的表,在表里加入了4个字段,并设置了一个主键。表里的字段分别输入4中不同的常用类型,第一个字段是一个自动增长的整数类型,这个类型比较特殊,你必须为这个字段设置ParentCatalog属性,并将“AutoIncrement”的属性值设为true.。Access里的Text类型对应的就是adVarWchar,而日期类型对应的是adDate。
键的设置如table.Keys.Append("FirstTablePrimaryKey", KeyTypeEnum.adKeyPrimary, column, null, null)所示,如果是外键的话,你还必须要设置关联的表和关联的字段,也就是Append方法的后两个字段。
你也可以参照上边的代码创建索引和视图。

三、C#创建Access数据库的备注字段

 原文:http://www.hackpig.cn/post/168.html

 

具体的用C#创建方式网上一堆,主要是创建备注字段的时候遇到的问题。
用ADOX创建的,在工程里添加引用dll就不说了,错误的步骤如下(就少了一步):
-------------------------------------------------------------------
            //创建库
            ADOX.CatalogClass catLog = new ADOX.CatalogClass();
            catLog.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source ="+path+";");
           
            //创建表
            ADOX.TableClass tbl = new ADOX.TableClass();
            tbl.ParentCatalog = catLog;
            tbl.Name = "NewTable";

            //增加字段
           ADOX.ColumnClass c = new ADOX.ColumnClass();
           c.ParentCatalog = catLog;
           c.Name = list1[i];
           c.Properties["Jet OLEDB:Allow Zero Length"].Value = true;
           tbl.Columns.Append(c, ADOX.DataTypeEnum.adLongVarWChar, 16);

            catLog.Tables.Append(tbl);
---------------------------------------------------------------------
Access的备注类型是Memo,不过在ADOX方式下,DataTypeEnum枚举里是没有这项的,adLongVarWChar就是备注,长度为16。这样创建,是不报错的,但是无论如何,建立出来的都是文本型的字段,最大长度限制是255,在内容很多的时候不够用,查了一堆,发现就是因为少了一句,正确的如下:

-------------------------------------
            //创建库
            ADOX.CatalogClass catLog = new ADOX.CatalogClass();
            catLog.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source ="+path+";");
           
            //创建表
            ADOX.TableClass tbl = new ADOX.TableClass();
            tbl.ParentCatalog = catLog;
            tbl.Name = "NewTable";

            //增加字段
           ADOX.ColumnClass c = new ADOX.ColumnClass();
           c.ParentCatalog = catLog;
           c.Type = ADOX.DataTypeEnum.adLongVarWChar; //这句不能少,并且位置必须在其它属性前面,否则会报错。
           c.Name = list1[i];
           c.Properties["Jet OLEDB:Allow Zero Length"].Value = true;
           tbl.Columns.Append(c, ADOX.DataTypeEnum.adLongVarWChar, 16);

            catLog.Tables.Append(tbl);
-------------------------------------

这样,就建立出来备注类型的字段了。

 

 

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

MySQL:世界上最受欢迎的数据库的简介 MySQL:世界上最受欢迎的数据库的简介 Apr 12, 2025 am 12:18 AM

MySQL是一种开源的关系型数据库管理系统,主要用于快速、可靠地存储和检索数据。其工作原理包括客户端请求、查询解析、执行查询和返回结果。使用示例包括创建表、插入和查询数据,以及高级功能如JOIN操作。常见错误涉及SQL语法、数据类型和权限问题,优化建议包括使用索引、优化查询和分表分区。

为什么要使用mysql?利益和优势 为什么要使用mysql?利益和优势 Apr 12, 2025 am 12:17 AM

选择MySQL的原因是其性能、可靠性、易用性和社区支持。1.MySQL提供高效的数据存储和检索功能,支持多种数据类型和高级查询操作。2.采用客户端-服务器架构和多种存储引擎,支持事务和查询优化。3.易于使用,支持多种操作系统和编程语言。4.拥有强大的社区支持,提供丰富的资源和解决方案。

apache怎么配置zend apache怎么配置zend Apr 13, 2025 pm 12:57 PM

如何在 Apache 中配置 Zend?在 Apache Web 服务器中配置 Zend Framework 的步骤如下:安装 Zend Framework 并解压到 Web 服务器目录中。创建 .htaccess 文件。创建 Zend 应用程序目录并添加 index.php 文件。配置 Zend 应用程序(application.ini)。重新启动 Apache Web 服务器。

如何利用Debian Apache日志提升网站性能 如何利用Debian Apache日志提升网站性能 Apr 12, 2025 pm 11:36 PM

本文将阐述如何通过分析Debian系统下的Apache日志来提升网站性能。一、日志分析基础Apache日志记录了所有HTTP请求的详细信息,包括IP地址、时间戳、请求URL、HTTP方法和响应代码等。在Debian系统中,这些日志通常位于/var/log/apache2/access.log和/var/log/apache2/error.log目录下。理解日志结构是有效分析的第一步。二、日志分析工具您可以使用多种工具分析Apache日志:命令行工具:grep、awk、sed等命令行工具可

apache服务器是什么 apache服务器是干嘛的 apache服务器是什么 apache服务器是干嘛的 Apr 13, 2025 am 11:57 AM

Apache服务器是强大的Web服务器软件,充当浏览器与网站服务器间的桥梁。1. 它处理HTTP请求,根据请求返回网页内容;2. 模块化设计允许扩展功能,例如支持SSL加密和动态网页;3. 配置文件(如虚拟主机配置)需谨慎设置,避免安全漏洞,并需优化性能参数,例如线程数和超时时间,才能构建高性能、安全的Web应用。

如何在Debian上监控Nginx SSL性能 如何在Debian上监控Nginx SSL性能 Apr 12, 2025 pm 10:18 PM

本文介绍如何在Debian系统上有效监控Nginx服务器的SSL性能。我们将使用NginxExporter将Nginx状态数据导出到Prometheus,再通过Grafana进行可视化展示。第一步:配置Nginx首先,我们需要在Nginx配置文件中启用stub_status模块来获取Nginx的状态信息。在你的Nginx配置文件(通常位于/etc/nginx/nginx.conf或其包含文件中)中添加以下代码段:location/nginx_status{stub_status

如何配置Debian Apache日志格式 如何配置Debian Apache日志格式 Apr 12, 2025 pm 11:30 PM

本文介绍如何在Debian系统上自定义Apache的日志格式。以下步骤将指导您完成配置过程:第一步:访问Apache配置文件Debian系统的Apache主配置文件通常位于/etc/apache2/apache2.conf或/etc/apache2/httpd.conf。使用以下命令以root权限打开配置文件:sudonano/etc/apache2/apache2.conf或sudonano/etc/apache2/httpd.conf第二步:定义自定义日志格式找到或

Nginx性能监控与故障排查工具使用 Nginx性能监控与故障排查工具使用 Apr 13, 2025 pm 10:00 PM

Nginx性能监控与故障排查主要通过以下步骤进行:1.使用nginx-V查看版本信息,并启用stub_status模块监控活跃连接数、请求数和缓存命中率;2.利用top命令监控系统资源占用,iostat和vmstat分别监控磁盘I/O和内存使用情况;3.使用tcpdump抓包分析网络流量,排查网络连接问题;4.合理配置worker进程数,避免并发处理能力不足或进程上下文切换开销过大;5.正确配置Nginx缓存,避免缓存大小设置不当;6.通过分析Nginx日志,例如使用awk和grep命令或ELK

See all articles