0

こんにちは、データグリッドビューからyアクセスデータベースにデータを更新および削除しようとしているプロジェクトで忙しいです。データグリッドビューで削除しますが、変更をデータベースに保存しないため、実際のデータベースで更新または削除することはありません。ご協力いただきありがとうございます。yコードは次のとおりです。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;

namespace Church_Network
{
    public partial class Form11 : Form
    {
    OleDbConnection con = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\Users\ELPARAISO\Desktop\icons\Church Network1\Church Network1\Church Network\Project.accdb");
    OleDbDataAdapter ad = new OleDbDataAdapter();
    DataSet ProjectDataSet3 = new DataSet();

    public Form11()
    {
        InitializeComponent();
    }

    private void button3_Click(object sender, EventArgs e)
    {
        saveToolStripButton.PerformClick();

        MessageBox.Show("updated");
    }

    private void button5_Click(object sender, EventArgs e)
    {
        try
        {
            ad.SelectCommand = new OleDbCommand("select* from Member ", con);
            ProjectDataSet3.Clear();
            ad.Fill(ProjectDataSet3);
            dataGridView1.DataSource = ProjectDataSet3.Tables[0];

           con.Open();
           ad.SelectCommand.ExecuteNonQuery();
            con.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message);
        }
    }

    private void Form11_Load(object sender, EventArgs e)
    {
        // TODO: This line of code loads data into the 'projectDataSet3.Member' table. You can move, or remove it, as needed.
        this.memberTableAdapter.Fill(this.projectDataSet3.Member);
    }

    private void button6_Click(object sender, EventArgs e)
    {
        Form8 f8 = new Form8();
        f8.Show();
    }

    private void button2_Click(object sender, EventArgs e)
    {
        bindingNavigatorDeleteItem.PerformClick();

        MessageBox.Show("deleted");

    }

    private void button1_Click(object sender, EventArgs e)
    {

    }
}

}

4

1 に答える 1

0

データベースを削除および更新するためのコマンドを追加する必要があります。あなたのコードにはこのようなものは見当たりません。

したがって、次のようなものを追加してみてください。

private void BtnDelete_Click(object sender, RoutedEventArgs e)
{
   DataRowView drv = (DataRowView)dataGridView1.SelectedItem;
   int id = drv.Row[0];
   if(drv != null)
   {
       delete(id);
   }
}

public void delete(int id)
{ 
   try 
   {
      con.Open();
      OleDbCommand comm = new OleDbCommand("delete from Member where id=@id", con);
      comm.Parameters.AddWithValue("@id", id);
      comm.ExecuteNonQuery();
   }
   catch(OleDbException ex)
   {
       MessageBox.Show("DataConnection not found!", ex);
   }
   finally
   {
       con.Close();
   }

また、Db の更新にも同じことが必要です。

于 2013-09-04T08:04:36.383 に答える