TECHNOLOGIES
FORUMS
JOBS
BOOKS
EVENTS
INTERVIEWS
Live
MORE
LEARN
Training
CAREER
MEMBERS
VIDEOS
NEWS
BLOGS
Sign Up
Login
No unread comment.
View All Comments
No unread message.
View All Messages
No unread notification.
View All Notifications
Answers
Post
An Article
A Blog
A News
A Video
An EBook
An Interview Question
Ask Question
Forums
Monthly Leaders
Forum guidelines
Andy Wij
NA
26
35.1k
Can't update record after call another form
Sep 27 2011 11:58 PM
I have a problem about .update() method Say that I have a table Currency with fields: Name, Symbol, Rate, and Country.
Form1 have a datagrid and button Edit, Form2 have a detail of selected record from Form1 in textbox.
So my problem is when I edit record in form2 and save it, datatable have change but not the database in server. am I missing something?
this is my code:
Form1
------
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.SqlClient;
using KK.Class;
namespace KK
{
namespace Master.Forms
{
public partial class Currency : Form
{
public SqlDataAdapter da = null;
public DataTable dt = null;
//public BindingSource bs = null;
//public DataSet ds;
private string sql = null;
//public DataViewManager dv;
public CurrencyManager myCurrencyManager = null;
public SqlCommandBuilder cb;
public Currency()
{
InitializeComponent();
}
private void Currency_Load(object sender, EventArgs e)
{
Connection con = new Connection();
sql = "select * from currency";
da = new SqlDataAdapter(sql, con.open_connection());
cb = new SqlCommandBuilder(da);
//ds = new DataSet();
dt = new DataTable();
//da.TableMappings.Add("Table", "Currency");
da.Fill(dt);
//bs = new BindingSource();
//bs.DataSource = dt;
grid_currency.DataSource = dt;
//da.Fill(ds);
//bs = new BindingSource();
//bs.DataSource = ds.Tables["Currency"];
//da.Fill(ds);
//grid_currency.DataSource = bs;
//dv = ds.DefaultViewManager;
txt_tes.DataBindings.Add("Text", dt, "Name");
myCurrencyManager = (CurrencyManager)this.BindingContext[dt];
//myCurrencyManager.Position = 0;
}
private void cmd_edt_Click(object sender, EventArgs e)
{
int position = Convert.ToInt32(myCurrencyManager.Position.ToString());
Currency_det currency_det = new Currency_det(da, dt, position);
currency_det.BindingContext = this.BindingContext;
if (currency_det.ShowDialog() == DialogResult.OK)
{
dt.AcceptChanges();
grid_currency.Refresh();
}
}
private void cmd_del_Click(object sender, EventArgs e)
{
try
{
grid_currency.Rows.RemoveAt(grid_currency.CurrentRow.Index);
da.Update(dt);
MessageBox.Show("Data success updated");
}
catch
{
MessageBox.Show("Data fail updated");
}
}
private void cmd_ext_Click(object sender, EventArgs e)
{
this.Close();
}
}
}
}
Form2
------
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.SqlClient;
namespace KK
{
namespace Master.Forms
{
public partial class Currency_det : Form
{
public DataTable dtt;
public SqlDataAdapter dat;
public CurrencyManager myCurrencyManager;
int position;
public SqlCommandBuilder cb;
public Currency_det(SqlDataAdapter dAdapter ,DataTable dTable,int pos)
{
position = pos;
dtt = dTable;
dat = dAdapter;
InitializeComponent();
}
private void Currency_det_Load(object sender, EventArgs e)
{
cb = new SqlCommandBuilder(dat);
myCurrencyManager = (CurrencyManager)this.BindingContext[dtt];
myCurrencyManager.Position = position;
txt_name.DataBindings.Add("Text", dtt , "Name");
txt_symbol.DataBindings.Add("Text", dtt, "Symbol");
txt_rate.DataBindings.Add("Text", dtt, "Rate");
txt_nation.DataBindings.Add("Text", dtt, "Country");
}
private void cmd_ext_Click(object sender, EventArgs e)
{
this.Close();
}
private void cmd_save_Click(object sender, EventArgs e)
{
dat.Update(dtt);
this.DialogResult = DialogResult.OK;
}
}
}
}
If I add/edit record directly from datagrid and call update method in form1 without call form2, It can successful update to grid.. But I don't want to make user to add/edit directly from datagrid, I want them to add/edit record on another form.. So am I missing something?
Reply
Answers (
3
)
How to Read, Modify, Save specific line in a .txt file c# ?
Creating and deleting files on a remote machine