C# | 将DataGridView中的数据保存到Accesss数据库

简介: 要将WinForm的DataGridView中的数据保存到Access数据库,可以按照本文的步骤进行。在Visual Studio中,打开项目,右键单击“引用”文件夹,选择“添加引用”,在“COM”选项卡中找到并选中“Microsoft Office 14.0 Access Database Engine Object Library”,然后单击“确定”按钮。

image.png

将DataGridView中的数据保存到Accesss数据库

要将WinForm的DataGridView中的数据保存到Access数据库,可以按照本文的步骤进行。

@[toc]

添加必要的引用

在Visual Studio中,打开项目,右键单击“引用”文件夹,选择“添加引用”,在“COM”选项卡中找到并选中“Microsoft Office 14.0 Access Database Engine Object Library”,然后单击“确定”按钮。

创建数据库连接:使用以下代码创建与Access数据库的连接:

string connString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\Users\username\Documents\database.accdb;Persist Security Info=False;";
OleDbConnection conn = new OleDbConnection(connString);

其中,“username”是当前登录用户的名称,“database.accdb”是Access数据库的名称和路径。

写插入数据的SQL语句

string sql = "INSERT INTO TableName (Column1, Column2, Column3) VALUES (@Value1, @Value2, @Value3)";

其中,“TableName”是Access数据库中要插入数据的表格名称,“Column1”、“Column2”和“Column3”是表格中的列名称,“@Value1”、“@Value2”和“@Value3”是要插入的值。

循环遍历DataGridView中的行并插入数据

使用以下代码遍历DataGridView中的行,并将数据插入到Access数据库中:

conn.Open();
OleDbCommand cmd = new OleDbCommand(sql, conn);
foreach (DataGridViewRow row in dataGridView1.Rows)
{
   
   
    cmd.Parameters.AddWithValue("@Value1", row.Cells["Column1"].Value);
    cmd.Parameters.AddWithValue("@Value2", row.Cells["Column2"].Value);
    cmd.Parameters.AddWithValue("@Value3", row.Cells["Column3"].Value);
    cmd.ExecuteNonQuery();
    cmd.Parameters.Clear();
}
conn.Close();

其中,“dataGridView1”是要保存数据的DataGridView控件的名称。

完整示例代码

string connString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\Users\username\Documents\database.accdb;Persist Security Info=False;";
OleDbConnection conn = new OleDbConnection(connString);
string sql = "INSERT INTO TableName (Column1, Column2, Column3) VALUES (@Value1, @Value2, @Value3)";
conn.Open();
OleDbCommand cmd = new OleDbCommand(sql, conn);
foreach (DataGridViewRow row in dataGridView1.Rows)
{
   
   
    cmd.Parameters.AddWithValue("@Value1", row.Cells["Column1"].Value);
    cmd.Parameters.AddWithValue("@Value2", row.Cells["Column2"].Value);
    cmd.Parameters.AddWithValue("@Value3", row.Cells["Column3"].Value);
    cmd.ExecuteNonQuery();
    cmd.Parameters.Clear();
}
conn.Close();

请注意,上述代码示例中的“Column1”、“Column2”和“Column3”应该替换为实际的列名称,而“@Value1”、“@Value2”和“@Value3”应该替换为您要插入的实际值。

相关文章
|
1月前
|
存储 人工智能 Cloud Native
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
在9月20日2024云栖大会上,阿里云智能集团副总裁,数据库产品事业部负责人,ACM、CCF、IEEE会士(Fellow)李飞飞发表《从数据到智能:Data+AI驱动的云原生数据库》主题演讲。他表示,数据是生成式AI的核心资产,大模型时代的数据管理系统需具备多模处理和实时分析能力。阿里云瑶池将数据+AI全面融合,构建一站式多模数据管理平台,以数据驱动决策与创新,为用户提供像“搭积木”一样易用、好用、高可用的使用体验。
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
|
25天前
|
存储 监控 数据处理
flink 向doris 数据库写入数据时出现背压如何排查?
本文介绍了如何确定和解决Flink任务向Doris数据库写入数据时遇到的背压问题。首先通过Flink Web UI和性能指标监控识别背压,然后从Doris数据库性能、网络连接稳定性、Flink任务数据处理逻辑及资源配置等方面排查原因,并通过分析相关日志进一步定位问题。
157 61
|
1月前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
135 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
23天前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
1月前
|
关系型数据库 分布式数据库 数据库
云栖大会|从数据到决策:AI时代数据库如何实现高效数据管理?
在2024云栖大会「海量数据的高效存储与管理」专场,阿里云瑶池讲师团携手AMD、FunPlus、太美医疗科技、中石化、平安科技以及小赢科技、迅雷集团的资深技术专家深入分享了阿里云在OLTP方向的最新技术进展和行业最佳实践。
|
22天前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
22天前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。
|
2月前
|
人工智能 Cloud Native 容灾
云数据库“再进化”,OB Cloud如何打造云时代的数据底座?
云数据库“再进化”,OB Cloud如何打造云时代的数据底座?
|
2月前
|
SQL 存储 关系型数据库
数据储存数据库管理系统(DBMS)
【10月更文挑战第11天】
136 3
|
2月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录