検索
ホームページデータベース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 までご連絡ください。
MySQLのデータベースアップグレードをどのように処理しますか?MySQLのデータベースアップグレードをどのように処理しますか?Apr 30, 2025 am 12:28 AM

MySQLデータベースをアップグレードする手順には次のものがあります。1。データベースをバックアップします。2。現在のMySQLサービスを停止します。3。MySQLの新しいバージョンをインストールします。アップグレードプロセス中に互換性の問題が必要であり、Perconatoolkitなどの高度なツールをテストと最適化に使用できます。

MySQLに使用できるさまざまなバックアップ戦略は何ですか?MySQLに使用できるさまざまなバックアップ戦略は何ですか?Apr 30, 2025 am 12:28 AM

MySQLバックアップポリシーには、論理バックアップ、物理バックアップ、増分バックアップ、レプリケーションベースのバックアップ、クラウドバックアップが含まれます。 1. Logical BackupはMySqldumpを使用してデータベースの構造とデータをエクスポートします。これは、小さなデータベースとバージョンの移行に適しています。 2.物理バックアップは、データファイルをコピーすることで高速かつ包括的ですが、データベースの一貫性が必要です。 3.インクリメンタルバックアップは、バイナリロギングを使用して変更を記録します。これは、大規模なデータベースに適しています。 4.レプリケーションベースのバックアップは、サーバーからバックアップすることにより、生産システムへの影響を減らします。 5. Amazonrdsなどのクラウドバックアップは自動化ソリューションを提供しますが、コストと制御を考慮する必要があります。ポリシーを選択するときは、データベースサイズ、ダウンタイム許容度、回復時間、および回復ポイントの目標を考慮する必要があります。

MySQLクラスタリングとは何ですか?MySQLクラスタリングとは何ですか?Apr 30, 2025 am 12:28 AM

mysqlclusteringenhancesdatabaserobustnessnessnessnessnessnistandistributiondistributingdataacrossmultiplenodes.itesthendbenginefordatareplication andfaulttolerance、保証highavailability.setupinvolvesconfiguringmanagement、data、ssqlnodes、carefulmonitoringringandpe

MySQLのパフォーマンスのためにデータベーススキーマ設計を最適化するにはどうすればよいですか?MySQLのパフォーマンスのためにデータベーススキーマ設計を最適化するにはどうすればよいですか?Apr 30, 2025 am 12:27 AM

MySQLのデータベーススキーマ設計の最適化は、次の手順を通じてパフォーマンスを改善できます。1。インデックス最適化:一般的なクエリ列にインデックスを作成し、クエリのオーバーヘッドのバランスをとり、更新を挿入します。 2。テーブル構造の最適化:正規化または反通常化によりデータ冗長性を削減し、アクセス効率を改善します。 3。データ型の選択:Varcharの代わりにINTなどの適切なデータ型を使用して、ストレージスペースを削減します。 4。パーティション化とサブテーブル:大量のデータボリュームの場合、パーティション化とサブテーブルを使用してデータを分散させてクエリとメンテナンスの効率を改善します。

MySQLのパフォーマンスをどのように最適化できますか?MySQLのパフォーマンスをどのように最適化できますか?Apr 30, 2025 am 12:26 AM

tooptimizemysqlperformance、soflowthesesteps:1)properindexingtospeedupqueries、2)useexplaintoanalyzeandoptimize Queryperformance、3)AductServerContingSettingStingsinginginnodb_buffer_pool_sizeandmax_connections、4)

データ処理と計算にMySQL関数を使用する方法データ処理と計算にMySQL関数を使用する方法Apr 29, 2025 pm 04:21 PM

MySQL関数は、データ処理と計算に使用できます。 1.基本的な使用には、文字列処理、日付計算、数学操作が含まれます。 2。高度な使用法には、複数の関数を組み合わせて複雑な操作を実装することが含まれます。 3.パフォーマンスの最適化では、Where句での機能の使用を回避し、GroupByおよび一時テーブルを使用する必要があります。

MySQLにデータを挿入する効率的な方法MySQLにデータを挿入する効率的な方法Apr 29, 2025 pm 04:18 PM

MySQLでデータを挿入するための効率的な方法には、次のものが含まれます。1。insertInto ...値構文、2。LoadDatainFileコマンドの使用、3。トランザクション処理の使用、4。バッチサイズの調整、5。Insurtignoreまたは挿入の使用...

フィールドをMySQLテーブルに追加および削除する手順フィールドをMySQLテーブルに追加および削除する手順Apr 29, 2025 pm 04:15 PM

MySQLでは、AlterTabletable_nameaddcolumnnew_columnvarchar(255)afterexisting_columnを使用してフィールドを追加し、andtabletable_namedopcolumncolumn_to_dropを使用してフィールドを削除します。フィールドを追加するときは、クエリのパフォーマンスとデータ構造を最適化する場所を指定する必要があります。フィールドを削除する前に、操作が不可逆的であることを確認する必要があります。オンラインDDL、バックアップデータ、テスト環境、および低負荷期間を使用したテーブル構造の変更は、パフォーマンスの最適化とベストプラクティスです。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。