C#DataGridView(使用DataSource填充)不保存到数据库

时间:2013-04-08 16:28:58

标签: c# database datagridview save datasource

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

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

我是新手用户所以我确定我做了一些愚蠢或天真的事情 - 我是否需要在这里添加一些sql调用?

有什么想法吗?

enter image description here

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);
        }
    }
}

1 个答案:

答案 0 :(得分: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;
    }
}

现在使用System.Data.OleDb;添加到您的form1顶部的标题中。

现在在public partial class EditUsers : Form put

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

最后在private void EditUsers_Load输入

c = new Connection();
            connect.ConnectionString = c.getConnection();