请教DataSet操作的问题

oop80 2004-11-02 04:31:47
有一个DataSet,
包含一个DataTable,
表名已知,第一列为主键。

现对该DataTable进行增、删、改操作后,
如何将更改回写到数据库中。
谢谢
...全文
238 27 打赏 收藏 转发到动态 举报
写回复
用AI写文章
27 条回复
切换为时间正序
请发表友善的回复…
发表回复
oop80 2004-11-05
  • 打赏
  • 举报
回复
没人啊?
oop80 2004-11-04
  • 打赏
  • 举报
回复
自己顶!!
oop80 2004-11-04
  • 打赏
  • 举报
回复
可以自己写insertcommand,updatecommand等命令来实现吗?
楚雄图灵 2004-11-04
  • 打赏
  • 举报
回复
public class AutoUpdateObj
{
private DataCatena DataCatena;
private SqlDataAdapter myDataAdapter;
private SqlCommandBuilder cb;
private DataSet ds;
/// <summary>
/// 自动更新
/// </summary>
/// <param name="Sqlstr"></param>
public AutoUpdateObj(string Sqlstr)
{
DataCatena = new DataCatena();
myDataAdapter = DataCatena.GetSqlDA(Sqlstr);
cb = new SqlCommandBuilder(myDataAdapter);
ds = new DataSet();
myDataAdapter.Fill(ds, "Table1");
}

/// <summary>
/// 更新SQL语句
/// </summary>
/// <param name="Sqlstr"></param>
public void SetUpdateCommand(string Sqlstr)
{
myDataAdapter.UpdateCommand = new SqlCommand(Sqlstr,myDataAdapter.SelectCommand.Connection);
}

/// <summary>
/// 设置Select语句
/// </summary>
/// <param name="Sqlstr"></param>
public void SetSelectCommand(string Sqlstr)
{
myDataAdapter.SelectCommand = new SqlCommand(Sqlstr,myDataAdapter.SelectCommand.Connection);
cb.DataAdapter = myDataAdapter ;
ds.Tables.Clear();
}

/// <summary>
/// 取得数据表
/// </summary>
/// <returns></returns>
public DataTable GetDataTable()
{
ds.Clear();
myDataAdapter.Fill(ds, "Table1");
return ds.Tables["Table1"];
}

/// <summary>
/// 取得数据适配器
/// </summary>
/// <returns></returns>
public SqlDataAdapter GetDataAdapter()
{
return myDataAdapter;
}

/// <summary>
/// 更新
/// </summary>
public void Update()
{
try
{
myDataAdapter.Update(ds, "Table1");
}
catch(SqlException sqlex)
{
MessageBox.Show("出错原因:"+sqlex.Message,"出错",MessageBoxButtons.OK,MessageBoxIcon.Error);
}
}
}
oop80 2004-11-04
  • 打赏
  • 举报
回复
我现在想给CSomeClass增加一个方法:CSomeClass.Update(DataSet ds)
该方法完成把对DataSet的更新回写数据库
请教Update的实现方法。
白云在上 2004-11-03
  • 打赏
  • 举报
回复
DataSet只是一个数据的集合,他与数据库或者其他数据源是隔离的。要把他写到数据库,你必须提供 DataAdapter , 同时还要有 InsertCommand 和 UpdateCommand,当然你也可以用 SqlCommandBuilder 自动获取。考虑
string selectCommandText = "Select * From Orders";
SqlDataAdapter sqlAda = new SqlDataAdapter(selectCommandText,sqlCon);
SqlCommandBuilder scb = new SqlCommandBuilder(sqlAda);
sqlAda.Update(dataSet);

前提是数据库内必须有 Orders 表且与 dataSet 中表的结构一样。
simonw 2004-11-03
  • 打赏
  • 举报
回复
参考duwamish
ljb1981216 2004-11-03
  • 打赏
  • 举报
回复
用DataAdapter.Update就行了
仓木泽 2004-11-03
  • 打赏
  • 举报
回复
DataSet ds = CSomeClass.ExecuteDataSet("SELECT * FROM Orders");
这个是你写的类吗?
那你直接new一个adpter来执行,应该可以的
yichuan1982 2004-11-03
  • 打赏
  • 举报
回复
帮你顶
baozi77 2004-11-03
  • 打赏
  • 举报
回复
帮顶!!!!
oop80 2004-11-03
  • 打赏
  • 举报
回复
没有人有办法解决啊。
oop80 2004-11-03
  • 打赏
  • 举报
回复
自己顶!
oop80 2004-11-03
  • 打赏
  • 举报
回复
问题是现在我不知道这个DataSet是怎么得到的,
也就是说,我这么得到DataSet的

DataSet ds = CSomeClass.ExecuteDataSet("SELECT * FROM Orders");
// 对ds进行增、删、改操作

那么我怎么样才能把对ds的修改回写数据库。。
rickjelly2004 2004-11-03
  • 打赏
  • 举报
回复
Dim selectstr As String
Dim cnn As SqlConnection
Dim sqldataset As DataSet
Dim sqlc As SqlCommand
Dim sqla As SqlDataAdapter
Dim sqlb As SqlCommandBuilder

cnn = New SqlConnection
sqldataset = New DataSet
cnn.ConnectionString = ConfigurationSettings.AppSettings("ConnectionString")

selectstr = "SELECT timetext FROM timetab"
sqlc = New SqlCommand(selectstr, cnn)
sqla = New SqlDataAdapter

sqla.SelectCommand = sqlc
sqlb = New SqlCommandBuilder(sqla)
sqla.Fill(sqldataset)

sqldataset.Tables(0).Rows(0).Delete()
sqla.Update(sqldataset)
oop80 2004-11-03
  • 打赏
  • 举报
回复
我没有dataadapter,
随便new一个出来?
aoyo 2004-11-02
  • 打赏
  • 举报
回复
要不就用SqlCommandBuilder自动生成执行的语句,
dataAdapter.UpdateCommand = SqlCommandBuilder.GetUpdateCommand();
aoyo 2004-11-02
  • 打赏
  • 举报
回复
DataSet都有了,通过它你就知道了数据表的结构了,只要写相应的执行语句,用DataAdapter.Update就行了
homesos 2004-11-02
  • 打赏
  • 举报
回复
不大适合用于这个地方
homesos 2004-11-02
  • 打赏
  • 举报
回复
如果只靠dataset本身好像不大好实现
最好能记录下他所做的修改,比如说日志什么的,那样就简单多了
呵呵呵呵
就是太繁了
加载更多回复(7)

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧