C#有关SqlDataAdapter和DataTable的更新
我利用一个dataGridView控件显示数据库中的一个表,并在dataGridView下方把表中各个条目列出,与dataGridView中的表绑定。更新下面的任何一个条...
我利用一个dataGridView控件显示数据库中的一个表,并在dataGridView下方把表中各个条目列出,与dataGridView中的表绑定。更新下面的任何一个条目,点击保存按钮,dataGridView中的表自动更改,并且更新数据库。
我写的语句是
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
adapter.Update(table);
目前只能在控件的表中更改,不能更新数据库,请哪位高手指点。
相关的代码在这里了:
DataTable table = new DataTable();
SqlConnection conn = new SqlConnection(Properties.Settings.Default.hrmdatabaseConnectionString);
SqlDataAdapter adapter = new SqlDataAdapter("select * from 职员基本信息表",conn);
adapter.Fill(table);
bindingSource1.DataSource = table;
dataGridView1.DataSource = bindingSource1;
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
adapter.Update(table); 展开
我写的语句是
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
adapter.Update(table);
目前只能在控件的表中更改,不能更新数据库,请哪位高手指点。
相关的代码在这里了:
DataTable table = new DataTable();
SqlConnection conn = new SqlConnection(Properties.Settings.Default.hrmdatabaseConnectionString);
SqlDataAdapter adapter = new SqlDataAdapter("select * from 职员基本信息表",conn);
adapter.Fill(table);
bindingSource1.DataSource = table;
dataGridView1.DataSource = bindingSource1;
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
adapter.Update(table); 展开
6个回答
展开全部
你的就是不能改变的,因为你根本没有用到dataset数据集!
dataset ds=new dataset()
adapter.fill(ds,"table");
你前面应该这样写。
后面更新的时候的代码:
SqlConnection conn = new SqlConnection
SqlDataAdapter adapter = new SqlDataAdapter("select * from 职员基本信息表",conn);
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
if (ds.haschanged())
{
dataset d=ds.getchanged();
adapter.update(d,"table);
ds.acceptchanged();
}ok!
dataset ds=new dataset()
adapter.fill(ds,"table");
你前面应该这样写。
后面更新的时候的代码:
SqlConnection conn = new SqlConnection
SqlDataAdapter adapter = new SqlDataAdapter("select * from 职员基本信息表",conn);
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
if (ds.haschanged())
{
dataset d=ds.getchanged();
adapter.update(d,"table);
ds.acceptchanged();
}ok!
展开全部
table.AcceptChanages();
adapter.Update(table);
试试看看,我一般从来都不用这种方式更新
adapter.Update(table);
试试看看,我一般从来都不用这种方式更新
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是"select * from 职员基本信息表",当然数据库里面没有更新了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是初学者吗?程序里用绑定,执行效率相对较低,并且代码繁多!有意详询,帐号即为QQ
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
把全部代码贴出看看 要不就不好说 a
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询