2

我有一个表单,我希望用户可以从数据库表“用户”中删除和编辑(而不是添加)行。我在 VS2010 中创建了一个表单和一个 DataSource,DataSource 是使用新的 DataSource 向导创建的。从这里,我将 DataSource 窗口条中的 Users 表的 DataGridView 拖放到表单中。

我遇到的问题是,当我运行应用程序时,数据会很好地加载到 DataGridView 中,但是当我删除或编辑一行并单击保存时,它不会更新数据库。

我是一个新手用户,所以我确定我做了一些愚蠢或幼稚的事情 - 我需要在这里添加一些 sql 调用吗?

有任何想法吗?

在此处输入图像描述

public partial class EditUsers : Form
{
    public EditUsers()
    {
        InitializeComponent();
    }

    private void EditUsers_Load(object sender, EventArgs e)
    {
        // TODO: This line of code loads data into the 'debenhamsProjectOfficeDatabaseDataSet.Users' table. You can move, or remove it, as needed.
        this.usersTableAdapter.Fill(this.debenhamsProjectOfficeDatabaseDataSet.Users);

    }

    private void usersBindingNavigatorSaveItem_Click(object sender, EventArgs e)
    {
        try
        {
            this.Validate();
            this.usersBindingSource.EndEdit();
            this.tableAdapterManager.UpdateAll(this.debenhamsProjectOfficeDatabaseDataSet);
            MessageBox.Show("Update successful");
        }
        catch (System.Exception ex)
        {
            MessageBox.Show(ex.Message);
        }
    }
}
4

1 回答 1

0

使用数据库填充数据网格视图的一种更灵活的方法是使用连接字符串。

在解决方案资源管理器中右键单击您的项目文件并添加一个新项目。添加一个类并将其命名为 connection.cs。在这里输入

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Your_Project_Name
{
class Connection
{
    string ConnectionString;
    public Connection()
    {
        ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;" +
        "Data Source=C:/User/somefolder/Your_Database.accdb;Persist Security Info=False;";

    }
    public string getConnection()
    {
        return ConnectionString;
    }
}

现在将 using 添加System.Data.OleDb;到 form1 顶部的标题中。

现在public partial class EditUsers : Form投入

OleDbConnection connect = new OleDbConnection();
        OleDbCommand command = new OleDbCommand();
        OleDbDataReader reader;
        Connection c;

最后private void EditUsers_Load输入

c = new Connection();
            connect.ConnectionString = c.getConnection();
于 2014-02-20T20:20:19.520 回答