社区
C#
帖子详情
急,dataset问题,高分求解
whblxl
2005-12-30 09:29:47
在dataset中有几个datatable:table1,table2,table3
我可以用sql语句在datatable之间执行update操作吗(避免使用循环)?
dataset与实际的数据库无关,几个datatable都是在程序中动态生成的,
并且几个datatable也都是动态生成的数据。
...全文
222
19
打赏
收藏
急,dataset问题,高分求解
在dataset中有几个datatable:table1,table2,table3 我可以用sql语句在datatable之间执行update操作吗(避免使用循环)? dataset与实际的数据库无关,几个datatable都是在程序中动态生成的, 并且几个datatable也都是动态生成的数据。
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
19 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
guopeng_028
2006-01-04
打赏
举报
回复
关注一下
whblxl
2006-01-04
打赏
举报
回复
昨天CSDN上不去,现在再up一下
whblxl
2006-01-02
打赏
举报
回复
calford(远方)
关于上面的解释能不能说的详细一点?
谢谢
zeusvenus
2005-12-31
打赏
举报
回复
一般在dt中修改数据还是直接赋值或通过修改dt的view来实现的比较多。
califord
2005-12-31
打赏
举报
回复
不知道上面的写那么多做什么,以下是我的回答
我可以用sql语句在datatable之间执行update操作吗(避免使用循环)?
建立一个方法呀,然后主要的语句用变量,就是说调用的是一个方法,而tabel1 tabel2等表里的update语句的参数按条件不同而变
dataset与实际的数据库无关,几个datatable都是在程序中动态生成的,
并且几个datatable也都是动态生成的数据。
这个你可以根据程序来写,要的时候才从数据库中读出来
whblxl
2005-12-31
打赏
举报
回复
我不需要把修改提交给数据库,只需要在datatable中修改数据,
而且不通过循环,最好用sql语句,有没有办法实现?
zeusvenus
2005-12-31
打赏
举报
回复
有问题再给我发消息。
zeusvenus
2005-12-31
打赏
举报
回复
datatable不能一次性直接提交到数据库,不过修改datatable数据后通过AcceptChanges可以进行更改,然后通过dataset提交到数据库或绑定到显示控件。
直接用一个sql语句在datatable之间执行update操作不行,但是可以通过datatable得copy/importrow等方法从datatable本身入手来完成你各个datatable间的数据操作。
上面的回答可能没有楼主的意思,不过我的可能也是:)
whblxl
2005-12-31
打赏
举报
回复
zhzuo(秋枫)
singlepine(小山)
ChengKing(Enthusiasm Bigrosoft)
几位星星都答非所问,各位有没有更加直接的回答?
desailly
2005-12-31
打赏
举报
回复
顶一下,方法很多,你用dataset操作数据以后,很方便也很快,更新数据库时,可以用楼上的方法较方便
lidong6
2005-12-31
打赏
举报
回复
动态生成的DataTable不能直接使用Update
要对DataAdapter中的SelectCommand,insertCommand,DeleteCommand都进行初始化后才可以调用DataAdapter.Update方法.
如果想看例子的话,可以在VS2003中新增项目:"数据窗体向导",然后生成的代码就是最好的范例.
jackyshower
2005-12-31
打赏
举报
回复
mark
whblxl
2005-12-31
打赏
举报
回复
大家帮我想一想,有没有别的办法呢?
eastasp
2005-12-30
打赏
举报
回复
关注
whblxl
2005-12-30
打赏
举报
回复
up
ChengKing
2005-12-30
打赏
举报
回复
(一) 序幕
当DataSet中同时包含主/子表(主键表/外键表)时,有时候关系约束太严格:
比如, 关系数据库完整性规则:
1.实体完整性. 主键表中主键不准为空.
2.参照完整性. 外键表中外键的值必须与主键表中的主键对应.
要么为空,要么为主键表中的一主键值.
3.自定义完整性.
如果DataSet表中定义的多表关系约束太严密,直接用Update方法
将DataSet中多表一起提交时,有可能不满足完整性规则,会发生错误,
原因: 举个例子,设为两个表: CompanyMain(公司主表)和CompanySon(公司子表)
CompanyMain(公司主表)主要存储一个公司的基本信息,CompanySon(公司子表)
主要存储此公司的一些客户的信息. 并且公司主表中的(ID)与子表中的(BelongID)
建立关联,即主外键关系; 一个公司对应着多个客户,即ID:BelongID = 1 : n关系.
主表的ID为自动生成编号.
那么:
在新增公司界面,一起提交时,系统是不会遵守"数据库完整性规则"来更新到数据库的.
如果它先更新子表,再更新主表有可能就会报错. 原因是主表的公司信息还没有插入
到数据库中的表,也就没有生成公司编号: ID,则子表更新时就会没有对应的BelongID.
这时如果设置了: "外键表中的外键不为null"完整性规则,就会引发异常.
这只是一种出错的可能,还有更多的出错可能性,在分布式设计中更容易出现这样的错误.
(二). 解决办法
一般遵守以下几条规则,就会避免大量的出错机率.
1规则. 在DataSet更新之前按 <表> 和 <表的RowState属性>进行拆分提交
I. 按 <表> 进行拆分提交意思是说:
对DataSet 中的表不是一起提交,而是一次提交一个表,进行多次提交
II.按 <表的RowState属性>进行拆分提交意思是说:
对DataSet中的单个表根据RowState属性,再进行拆分,对RowState
相同的进行一次提交,也是提交多次
2.规则.
在规则1基础上, 先更新状态为<新增> 和 <修改> 的,再更新<删除的>
即: 先更新DataRowState 值为: Added和Modified的,再更新: Deleted的.
3.规则
在规则1和规则2基础上,如果DataRowState为Added和Modified,则先更新主表,后更新子表.
在规则1和规则2基础上,如果DataRowState为Deleted,则先更新子表,后更新主表.
(三) 归纳一下上面三条规则,如下:
1.将DataSet中的表拆分,并根据RowState将各个表记录进行分组并存储在不同的数据集中
//这里要存储在DataSet中,是因为: Update接受的是DataSet的参数,还有WebService只支持
//DataSet,对其进行序列化操作
代码示例:
设待更新的数据集为: dsCompany(里面包括两个表,分别为主表和子表,并存储了
数据,待更新)
//dtCompanyMain存储公司主表信息,dtCompanySon存储公司子表信息
DataTable dtCompanyMail = ds.Tables["dtCompanyMain"].Clone(); //分离出主表数据
并存储另一对象
DataTable dtCompanySon = ds.Talbes["dtCompanySon"].Clone(); //分离出子表数据
并存储另一对象
DataSet dsAdded = new DataSet(); //存放主表 新增 的数据
DataSet dsMidified = new DataSet(); //存储主表 编辑 的行记录
DataSet dsDeleted = new DataSet(); //存储主表 删除 的行记录
dsAdded = dtCompanyMain.GetChanges(DataRowState.Added); //取得主表中新增的行
记录集
dsMidified = dtCompanyMain.GetChanges(DataRowState.Modified); //取得主表中编
辑的行记录集
dsDeleted = dtCompanyMain.GetChanges(DataRowState.Deleted); //取得主表中删除的
行记录集
2.更新主表DataRowState状态为: Added和Modified的记录.
SqlDataAdapter.Update(dsAdded,"dtCompanyMain"); //更新添加的记录集到数据库
SqlDataAdapter.Update(dsModified,"dtCompanyMain"); //更新修改的记录集到数据
库
3.更新子表DataRowState状态为: Added和Modified的记录
............. //代码省略,跟2主表更新类似
4.更新子表DataRowState状态为: Deleted的记录.
............ // 代码省略,与下面5类似
5.更新主表DataRowState状态为: Deleted的记录
SqlDataAdapter.Update(dsDeleted,"dtCompanyMain"); //更新修改的记录集到数据库
singlepine
2005-12-30
打赏
举报
回复
动态构造sql语句和传递参数,主要用到代码如下,具体参考
http://singlepine.cnblogs.com/articles/255374.html
public static void UpdateTable(DataTable dt,string TableName,string KeyName)
{
foreach(DataRow dr in dt.Rows)
{
updateRow(dr,TableName,KeyName);
}
}
private static void updateRow(DataRow dr,string TableName,string KeyName)
{
if (dr[KeyName]==DBNull.Value )
{
throw new Exception(KeyName +"的值不能为空");
}
if (dr.RowState ==DataRowState.Deleted)
{
deleteRow(dr,TableName,KeyName);
}
else if (dr.RowState ==DataRowState.Modified )
{
midifyRow(dr,TableName,KeyName);
}
else if (dr.RowState ==DataRowState.Added )
{
insertRow(dr,TableName,KeyName);
}
else if (dr.RowState ==DataRowState.Unchanged )
{
midifyRow(dr,TableName,KeyName);
}
}
private static void midifyRow(DataRow dr,string TableName,string KeyName)
{
string UpdateSql = "Update {0} set {1} {2}";
string setSql="{0}= @{0}";
string wherSql=" Where {0}=@{0}";
StringBuilder setSb = new StringBuilder();
SqlCommand sqlcom=new SqlCommand();
DataTable dtb=dr.Table;
for (int k=0; k<dr.Table.Columns.Count; ++k)
{
System.Data.IDataParameter iparam=new SqlParameter();
iparam.ParameterName = "@"+ dtb.Columns[k].ColumnName;
iparam.DbType = GetDbType(dtb.Columns[k].DataType);
iparam.Value = dr[k];
sqlcom.Parameters .Add(iparam);
if (dtb.Columns[k].ColumnName==KeyName)
{
wherSql=string.Format(wherSql,KeyName);
}
else
{
setSb.Append(string.Format(setSql,dtb.Columns[k].ColumnName));
setSb.Append(",");
}
}
string setStr=setSb.ToString();
setStr=setStr.Substring(0,setStr.Length -1); //trim ,
string sql = string.Format(UpdateSql, TableName, setStr,wherSql);
sqlcom.CommandText =sql;
try
{
ExecCommand(sqlcom);
}
catch(Exception ex)
{
throw ex;
}
}
private static void deleteRow(DataRow dr,string TableName,string KeyName)
{
string sql="Delete {0} where {1} =@{1}";
DataTable dtb=dr.Table ;
sql=string.Format(sql,TableName,KeyName);
SqlCommand sqlcom=new SqlCommand(sql);
System.Data.IDataParameter iparam=new SqlParameter();
iparam.ParameterName = "@"+ KeyName;
iparam.DbType = GetDbType(dtb.Columns[KeyName].DataType);
iparam.Value = dr[KeyName];
sqlcom.Parameters .Add(iparam);
ExecCommand(sqlcom);
}
marvelstack
2005-12-30
打赏
举报
回复
在多表有关系的情况下数据更新
http://blog.csdn.net/zhzuo/archive/2004/08/06/67037.aspx
wmhnq
2005-12-30
打赏
举报
回复
up
The highD
Dataset
: A Drone
Dataset
of Naturalistic Vehicle Trajectories on German Highways for Valid
摘要-基于场景的
高
度自动化车辆的安全验证测试是一种很有前途的方法,目前正在研究和工业中进行研究。这种方法在很大程度上依赖于来自真实场景的数据来获得进行测试所需的场景信息。测量数据应以合理的努力收集,包含道路使用者的自然行为,并包括所有与描述已确定的场景相关的数据。然而,目前的测量方法至少不能满足其中一项要求。因此,我们提出了一种新的方法,从空中的角度测量数据,以实现基于场景的验证,满足上述要求。此外,我们还提供了一个来自德国
高
速公路的大规模自然车辆轨道数据集,称为highD。
Mining of Massive
Dataset
笔记
一、概述 1、这本书是关于“data mining”的,但是它的关注点是在大数据挖掘上,它的观点是“在大数据上应用算法去挖掘信息,而不是使用ML去训练大数据” Data mining is about applying algorithms to data, rather than using data to “train” a machine-learning engine of some ...
T-LESS: An RGB-D
Dataset
for 6D Pose Estimation of Texture-less Objects
T-LESS: An RGB-D
Dataset
for 6D Pose Estimation of Texture-less Objects如有错误,欢迎指正摘要3. The T-LESS
Dataset
如有错误,欢迎指正 本文翻译为机翻,仅作初步了解学习使用,需要用到的时候再回来整理。 如有侵权,请私信本人。 原文链接: https://arxiv.org/pdf/1701.05498.pdf 参考链接: 摘要 3. The T-LESS
Dataset
...
浪潮“源”AI大模型如何
求解
数学应用题
浪潮“源”AI大模型如何
求解
数学应用题
DAIR-V2X: A Large-Scale
Dataset
for Vehicle-Infrastructure Cooperative 3D Object Detection
自动驾驶的安全全局视野和远程感知能力的限制,自动驾驶面临着巨大的安全挑战。
C#
110,567
社区成员
642,567
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章