mam pytanie co do datagrid w C#, otoz w tym projekcie pliki:
Przede wszystkim zacznij pisać kod na tym forum, zamiast podawania linków do plików RAR .. wiesz mi - mało komu będzie się chciało tam wchodzić, ściągać to, rozpakowywać. To samo obrazki - wrzuć na imageshack i podaj tu obrazek, żebyśmy to widzieli.
ok w takim razie to jest Form1.cs
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace Biblioteka
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
this.toolStripComboBox1.Items.Clear();
foreach (DataTable t in this.database1DataSet.Tables)
{
this.toolStripComboBox1.Items.Add(t);
}
this.toolStripComboBox1.Text = this.toolStripComboBox1.Items[0].ToString();
}
private void toolStripButton1_Click(object sender, EventArgs e)
{
if (this.toolStripComboBox1.Text != "")
{
if (this.toolStripComboBox1.Text == this.database1DataSet.wyporzyczenia.TableName)
{
this.dataGridView1.DataSource = wyporzyczeniaBindingSource;
this.bindingNavigator1.BindingSource = wyporzyczeniaBindingSource;
// TODO: This line of code loads data into the 'database1DataSet.wyporzyczenia' table. You can move, or remove it, as needed.
this.wyporzyczeniaTableAdapter.Fill(this.database1DataSet.wyporzyczenia);
}
// TODO: This line of code loads data into the 'database1DataSet.osoby' table. You can move, or remove it, as needed.
if (this.toolStripComboBox1.Text == this.database1DataSet.osoby.TableName)
{
this.dataGridView1.DataSource = osobyBindingSource;
this.bindingNavigator1.BindingSource = osobyBindingSource;
this.osobyTableAdapter.Fill(this.database1DataSet.osoby);
}
// TODO: This line of code loads data into the 'database1DataSet.ksiazki' table. You can move, or remove it, as needed.
if (this.toolStripComboBox1.Text == this.database1DataSet.ksiazki.TableName)
{
this.dataGridView1.DataSource = ksiazkiBindingSource;
this.bindingNavigator1.BindingSource = ksiazkiBindingSource;
this.ksiazkiTableAdapter.Fill(this.database1DataSet.ksiazki);
}
// TODO: This line of code loads data into the 'database1DataSet.autorzy' table. You can move, or remove it, as needed.
if (this.toolStripComboBox1.Text == this.database1DataSet.autorzy.TableName)
{
this.dataGridView1.DataSource = autorzyBindingSource;
this.bindingNavigator1.BindingSource = autorzyBindingSource;
this.autorzyTableAdapter.Fill(this.database1DataSet.autorzy);
}
}
}
private void bindingNavigatorAddNewItem_Click(object sender, EventArgs e)
{
}
private void bindingNavigatorDeleteItem_Click(object sender, EventArgs e)
{
}
}
}
chodzi o ten przyciski zaznaczone
http://kolos.math.uni.lodz.pl/~bart/screen.JPG
skad on wie ze usuwam akurat ten klikniety rekord na grid'zie? i co zrobic zeby edycja zaczela dzialac?
Po usunięciu z DataGridView, jeśli DataSource jest ustawiony na jakiś DataSet lub DataTable - automatycznie zmienia się w tych kontenerach. Aby zmiany zaszły również w bazie - trzeba wykonać metodę Update() .. - dodatkowo Adapter musi znać jakiego polecenia użyć, aby tego dokonać (SQL Query).
Tutaj masz przykład z mojego programu:
// Aytomatyczne budowanie poleceń
OleDbCommandBuilder SBuilder = new OleDbCommandBuilder(Adapter);
// Update tabeli o indeksie 0
Adapter.Update(SomeDataSet.Tables[0]);
Więcej znajdziesz tutaj: http://www.codeproject.com/cs/database/DataGridView2Db.asp