一个简单的 WinForm 读写 ACCESS 数据库程序,实现了基本的增删改查功能:

1. 创建一个 WinForm 窗口,在窗口中添加以下控件:

  - 一个 DataGridView 控件,用于显示数据库中的数据;
  - 一些 Label 和 TextBox 控件,用于输入和显示要操作的数据;
  - 一些 Button 控件,用于触发操作。

2. 在窗口的代码文件中添加以下代码:

using System;
using System.Data.OleDb;
using System.Windows.Forms;

namespace AccessDemo
{
    public partial class MainForm : Form
    {
        private OleDbConnection connection;
        private OleDbDataAdapter adapter;
        private DataTable dataTable;

        public MainForm()
        {
            InitializeComponent();

            // 初始化数据库连接和数据适配器
            connection = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=database.accdb;");
            adapter = new OleDbDataAdapter("SELECT * FROM users", connection);
            dataTable = new DataTable();
            adapter.Fill(dataTable);

            // 绑定数据到 DataGridView 控件
            dataGridView.DataSource = dataTable;
        }

        private void MainForm_FormClosing(object sender, FormClosingEventArgs e)
        {
            // 关闭数据库连接
            connection.Close();
        }

        private void addButton_Click(object sender, EventArgs e)
        {
            // 插入一条新记录
            string sql = "INSERT INTO users (name, age) VALUES (@name, @age)";
            OleDbCommand command = new OleDbCommand(sql, connection);
            command.Parameters.AddWithValue("@name", nameTextBox.Text);
            command.Parameters.AddWithValue("@age", ageTextBox.Text);
            connection.Open();
            command.ExecuteNonQuery();
            connection.Close();

            // 刷新 DataGridView 控件的数据
            dataTable.Clear();
            adapter.Fill(dataTable);
        }

        private void deleteButton_Click(object sender, EventArgs e)
        {
            // 删除选中的记录
            if (dataGridView.SelectedRows.Count > 0)
            {
                int id = (int)dataGridView.SelectedRows[0].Cells["id"].Value;
                string sql = "DELETE FROM users WHERE id = @id";
                OleDbCommand command = new OleDbCommand(sql, connection);
                command.Parameters.AddWithValue("@id", id);
                connection.Open();
                command.ExecuteNonQuery();
                connection.Close();

                // 刷新 DataGridView 控件的数据
                dataTable.Clear();
                adapter.Fill(dataTable);
            }
        }

        private void updateButton_Click(object sender, EventArgs e)
        {
            // 更新选中的记录
            if (dataGridView.SelectedRows.Count > 0)
            {
                int id = (int)dataGridView.SelectedRows[0].Cells["id"].Value;
                string sql = "UPDATE users SET name = @name, age = @age WHERE id = @id";
                OleDbCommand command = new OleDbCommand(sql, connection);
                command.Parameters.AddWithValue("@name", nameTextBox.Text);
                command.Parameters.AddWithValue("@age", ageTextBox.Text);
                command.Parameters.AddWithValue("@id", id);
                connection.Open();
                command.ExecuteNonQuery();
                connection.Close();

                // 刷新 DataGridView 控件的数据
                dataTable.Clear();
                adapter.Fill(dataTable);
            }
        }

        private void searchButton_Click(object sender, EventArgs e)
        {
            // 根据姓名搜索记录
            string name = nameTextBox.Text;
            string sql = "SELECT * FROM users WHERE name LIKE @name";
            OleDbCommand command = new OleDbCommand(sql, connection);
            command.Parameters.AddWithValue("@name", "%" + name + "%");
            DataTable searchResult = new DataTable();
            adapter.SelectCommand = command;
            adapter.Fill(searchResult);
            dataGridView.DataSource = searchResult;
        }
    }
}

3. 在窗口的设计器中,将各个控件的事件与上述方法绑定。

4. 将数据库文件(.accdb)放到程序的运行目录下,并修改连接字符串中的文件名为相应的文件名。

5. 运行程序,即可进行基本的增删改查操作。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

二月刀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值