C#中如何进行Access数据库的数据迁移

avatar
作者
筋斗云
阅读量:0

在C#中,要进行Access数据库的数据迁移,你可以使用OLEDB连接到Access数据库,然后使用SQL语句来查询、插入、更新或删除数据。以下是一个简单的示例,展示了如何将数据从一个Access数据库迁移到另一个Access数据库。

  1. 首先,确保已经安装了适当版本的Microsoft Access Database Engine。根据你的操作系统和Office版本,你需要安装32位或64位的引擎。下载地址:https://www.microsoft.com/en-us/download/details.aspx?id=54920

  2. 在Visual Studio中创建一个新的C#控制台应用程序项目。

  3. 添加以下命名空间引用:

using System; using System.Data; using System.Data.OleDb; 
  1. 编写以下代码来迁移数据:
class Program {     static void Main(string[] args)     {         // 源数据库文件路径         string sourceFilePath = @"C:\path\to\source\database.mdb";         // 目标数据库文件路径         string targetFilePath = @"C:\path\to\target\database.mdb";          // 源数据库连接字符串         string sourceConnectionString = $"Provider=Microsoft.Jet.OLEDB.4.0;Data Source={sourceFilePath};Persist Security Info=False;";         // 目标数据库连接字符串         string targetConnectionString = $"Provider=Microsoft.Jet.OLEDB.4.0;Data Source={targetFilePath};Persist Security Info=False;";          // 定义要迁移的表名         string tableName = "TableName";          // 查询源数据库中的数据         DataTable dataToMigrate = new DataTable();         using (OleDbConnection sourceConnection = new OleDbConnection(sourceConnectionString))         {             sourceConnection.Open();             using (OleDbCommand command = new OleDbCommand($"SELECT * FROM {tableName}", sourceConnection))             {                 using (OleDbDataReader reader = command.ExecuteReader())                 {                     dataToMigrate.Load(reader);                 }             }         }          // 将数据插入到目标数据库中         using (OleDbConnection targetConnection = new OleDbConnection(targetConnectionString))         {             targetConnection.Open();             using (OleDbCommand command = new OleDbCommand())             {                 command.Connection = targetConnection;                  foreach (DataRow row in dataToMigrate.Rows)                 {                     command.CommandText = $"INSERT INTO {tableName} (Column1, Column2, Column3) VALUES (@Column1, @Column2, @Column3)";                     command.Parameters.Clear();                     command.Parameters.AddWithValue("@Column1", row["Column1"]);                     command.Parameters.AddWithValue("@Column2", row["Column2"]);                     command.Parameters.AddWithValue("@Column3", row["Column3"]);                      command.ExecuteNonQuery();                 }             }         }          Console.WriteLine("数据迁移完成!");         Console.ReadLine();     } } 

请注意,你需要根据实际情况修改源数据库和目标数据库的文件路径、表名和列名。此外,这个示例仅用于演示目的,实际应用中可能需要进行错误处理和优化。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!