Dataset 的 Adapter Updata没有作用

sameal 2008-12-09 05:02:08
数据库死活没有反应
目的是把objdataset1的数据插到tempdata中,这两个都是dataset
并且和Gridview2绑定显示,数据成功插入tempdata
但是最后一步Updata却无反应,
表设置了主键

String DatabaseConnectString = "Data Source=orcl;Persist Security Info=True;User ID=scott;Password=cat;";
OracleConnection OracleConn = new OracleConnection(DatabaseConnectString);
OracleConn.Open();
OracleDataAdapter adapter=new OracleDataAdapter();
OracleCommand slc = new OracleCommand("SELECT * FROM DUMMY_DOMAIN", OracleConn);

adapter.SelectCommand = slc;
OracleCommandBuilder ocb = new OracleCommandBuilder(adapter);

DataSet tempData = new DataSet();
adapter.FillSchema(tempData, SchemaType.Source, "DUMMY_DOMAIN");
adapter.MissingSchemaAction = MissingSchemaAction.AddWithKey;
adapter.Fill(tempData,"DUMMY_DOMAIN");

foreach (DataRow dr in objDataset1.Tables[0].Rows)
{
tempData.Tables[0].ImportRow(dr);
}

GridView2.DataSource = tempData;
GridView2.DataBind();

adapter.Update(tempData, "DUMMY_DOMAIN");

OracleConn.Close();
...全文
105 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
dengmingcai 2008-12-16
  • 打赏
  • 举报
回复
up
BEN254422571 2008-12-09
  • 打赏
  • 举报
回复
我以前也做过这样的操作!要用适配器读取数据库的表数据放入DATASET结果集中的Table,
然后再这Table中添加数据,删除数据,更新数据,然后将Updata(修改后的表)

using (GetSqlConn()) //GetSqlConn()自定义连接方法!!
{
//创建适配器
SqlDataAdapter dataAdapter = new SqlDataAdapter("select * from tables", conn);

DataSet a = new DataSet();

dataAdapter.Fill(a);

// .....对a的TABLE插入N行数据!!!

//执行更新

SqlCommandBuilder builder = new SqlCommandBuilder(dataAdapter);

dataAdapter.Update(a);

}


//这里操作SQL数据库
sameal 2008-12-09
  • 打赏
  • 举报
回复

foreach (DataRow dr in objDataset1.Tables[0].Rows)
{
DataRow nwdr=tempData.Tables[0].NewRow();
nwdr["DQ_NUM"]=dr["DQ_NUM"];
nwdr["DQ_NAME"] = dr["DQ_NAME"];
nwdr["DQ_TEXT"] = dr["DQ_TEXT"];
tempData.Tables[0].Rows.Add(nwdr);

}

把循环改成这样就可以了
其实第一位兄弟就说对了 只是我没明白过来
多谢楼上几位的帮忙
DavidNoWay 2008-12-09
  • 打赏
  • 举报
回复
Mark
zcandyly20211 2008-12-09
  • 打赏
  • 举报
回复
up
sameal 2008-12-09
  • 打赏
  • 举报
回复
不想用sql啊,这样封装总觉得不彻底
决定在循环里新建DataRow 然后对DataRow各项幅值,最后插进去。
sikezx 2008-12-09
  • 打赏
  • 举报
回复
是啊,直接用sql不就行了么?
sameal 2008-12-09
  • 打赏
  • 举报
回复
喔,原来如此,果然是这个原因 多谢兄台
经兄台提示 我搜到一篇帖子
http://topic.csdn.net/t/20050520/15/4022937.html首先要知道DataAdapter.Update方法的运行原理,

原始的DataTable,所有行的状待(DataRowState)都是没有改变的
当操作其中的数据时,相应的行状态会被更改,例如删除一行,DataRowState状态就被改为Delete
最后,调用UPdate()的时候就检索一下行状态,凡是有更改的行都自动生成一下sql语句反映到数据库

有不少人有这个误会:DataAdapter.Update方法是跟数据库的数据进行比较有更改的就更新==绝对是个误解!

ds2.Merge(ds1),那么ds2就成了ds1了,里面的数据行的状态没有记录任何更改,所以能成功运行,但是数据没有更改;

遗憾的是DataRowState是个只读属性,没办法手动更改之,因此只能一行一行地进行处理,而不能使用merge方法


那么问题似乎明白了,但是怎么解决呢?DataRowState又改不成。还是要用SQL么?
flyjimi 2008-12-09
  • 打赏
  • 举报
回复
foreach (DataRow dr in objDataset1.Tables[0].Rows)
{
tempData.Tables[0].ImportRow(dr);
}

这个循环执行的时候,objDataset1.Tables[0] 中的行修改了吗,做过什么操作。
ImportRow 会复制dr的DataRowState 。
也就是说ImportRow 不等于新增行。
sameal 2008-12-09
  • 打赏
  • 举报
回复

"DELETE FROM DUMMY_DOMAIN WHERE ((DQ_NUM = :p1) AND ((:p2 = 1 AND DQ_NAME IS NULL) OR (DQ_NAME = :p3)) AND ((:p4 = 1 AND DQ_TEXT IS NULL) OR (DQ_TEXT = :p5)))"

"UPDATE DUMMY_DOMAIN SET DQ_NUM = :p1, DQ_NAME = :p2, DQ_TEXT = :p3 WHERE ((DQ_NUM = :p4) AND ((:p5 = 1 AND DQ_NAME IS NULL) OR (DQ_NAME = :p6)) AND ((:p7 = 1 AND DQ_TEXT IS NULL) OR (DQ_TEXT = :p8)))"

"INSERT INTO DUMMY_DOMAIN (DQ_NUM, DQ_NAME, DQ_TEXT) VALUES (:p1, :p2, :p3)"

ocb生成代码是这样的
update之后再给数据集tempdata加上acceptChanges()方法么?
我刚才试了 没有什么作用
chagel 2008-12-09
  • 打赏
  • 举报
回复
你把ocb的更新方法的sql打出来看一下有没有问题
ocb.GetUpdateCommand().CommandText
update之后,加上AcceptChanges()方法
sameal 2008-12-09
  • 打赏
  • 举报
回复
我在这里
GridView2.DataSource = tempData;
GridView2.DataBind();
把插入之后tempdata显示在页面上
显示出插入后的数据
update后用sqlplus查数据库发现没有东西插入...
但是写sqlcommand然后执行是可以的
MicroDeviser 2008-12-09
  • 打赏
  • 举报
回复
跟踪一下,看看tempData的行状态
sameal 2008-12-09
  • 打赏
  • 举报
回复
我插入了行啊,这难道不算修改么?
MicroDeviser 2008-12-09
  • 打赏
  • 举报
回复
怎么会有反映,你都没有修改数据!
zhu4139365 2008-12-09
  • 打赏
  • 举报
回复
up
1,主界面 2查询功能 ‘ private void chaxun_Click(object sender, System.EventArgs e) { SqlConnection thisConnection=new SqlConnection("Data Source=LocalHost;Integrated Security=SSPI;Initial Catalog=李梦然07060021"); //表示到SQL Server的一个实例的连接 SqlCommand thisCommand=new SqlCommand("select * from student where sno='"+textBox1.Text+"'",thisConnection); SqlDataAdapter thisAdapter=new SqlDataAdapter(); thisAdapter.SelectCommand=thisCommand; DataSet thisDataSet=new DataSet(); thisConnection.Open(); thisAdapter.Fill(thisDataSet, "student"); //在运行时设置 dataGrid1的数据源和数据成员属性,即在dataGrid1中显示数据集中的数据 dataGrid1.SetDataBinding(thisDataSet,"student"); thisConnection.Close(); } 3浏览功能 private void liulan_Click(object sender, System.EventArgs e) { //用SqlConnection对象连接SQL Server数据库魏菊丽20086666 SqlConnection thisConnection=new SqlConnection("Data Source=LocalHost;Integrated Security=SSPI;Initial Catalog=李梦然07060021"); SqlDataAdapter thisAdapter=new SqlDataAdapter(); DataSet thisDataSet=new DataSet(); //创建并返回一个与SqlConnection相关联的SqlCommand 对象 SqlCommand thisCommand=thisConnection.CreateCommand(); thisCommand.CommandText="select * from student";//获取或设置要对数据源执行的SQL语句 thisAdapter.SelectCommand =thisCommand ;//获取一个SQL语句,用于在数据源中选择记录 thisConnection.Open();//打开本次设置的数据库连接 thisAdapter.Fill(thisDataSet,"student");//将以上在数据源student中选择的记录的所有行填充到数据集中。 thisConnection.Close();//断开本次数据库连接 //在运行时设置 dataGrid1的数据源和数据成员属性,即在dataGrid1中显示数据集中的数据 dataGrid1.SetDataBinding(thisDataSet,"student"); } 4,插入一个新列 private void button1_Click(object sender, System.EventArgs e) { SqlConnection thisConnection=new SqlConnection("Data Source=LocalHost;Integrated Security=SSPI;Initial Catalog=李梦然07060021"); SqlDataAdapter thisAdapter=new SqlDataAdapter(); DataSet thisDataSet=new DataSet(); SqlCommand thisCommand=thisConnection.CreateCommand(); thisCommand.CommandText="select * from student "; thisAdapter.SelectCommand =thisCommand ; thisConnection.Open(); SqlCommandBuilder thisBuilder = new SqlCommandBuilder(thisAdapter); thisAdapter.Fill(thisDataSet, "student"); DataRow thisRow=thisDataSet.Tables["student"].NewRow();//在 数据集的student Table中创建新行 thisRow["sno"]="21";thisRow["sname"]="李梦然";thisRow["ssex"]="男";thisRow["thirthday"]="1987-7-31";thisRow["class"]="95001";//设置新行中的个字段值 thisDataSet.Tables["student"].Rows.Add(thisRow);//将新行添加到数据集的student Table中 thisAdapter.Update(thisDataSet,"student");// 修改数据库表 //以下显示添加后表中的数据 thisCommand.CommandText="select * from student "; thisAdapter.SelectCommand =thisCommand ; dataGrid1.SetDataBinding(thisDataSet,"student"); thisConnection.Close(); }
不定项选择题(共14题,单选或多选): 一、一个HTML文档必须包含三个元素,它们是head、html和( )。 A.scriptB.bodyC.titleD.link 二、下面哪段javascript能弹出一个提示框?( ) A.document.alert(test) B.window.alert(test) C.document.alert('test ') D.window.alert('test ') 三、当鼠标放在一个链接上的css样式应该( )伪类来定义。 A.a:visitedB.a:linkC.a:hoverD.a:active 四、关于ASP.NET中的代码隐藏文件的描述正确的是( )。 A.Web窗体页的程序的逻辑由代码组成,这些代码的创建用于与窗体交互。该文件称作为“代码隐藏”文件,如果用C#创建,该文件将具有“.ascx.cs”扩展名 B.web窗体也是类 C.项目中所有的Web窗体页的代码隐藏文件都被编译成项目动态链接库(.dll)文件 D.以上都不正确 五、下列ASP.NET语句( )正确地创建了一个与SQL Server数据库的连接。 A.SqlConnection con1 = new Connection(“Data Source = localhost; Trusted_Connection =Yes; Initial Catalog = myDB”); B.SqlConnection con1 = new SqlConnection(“Data Source = localhost; Trusted_Connection =Yes; Initial Catalog = myDB”); C.SqlConnection con1 = new OleDbConnection(“Data Source = localhost; Trusted_Connection =Yes; Initial Catalog = myDB”); D.SqlConnection con1 = new SqlConnection(Data Source = localhost; Trusted_Connection =Yes; Initial Catalog = myDB); 六、执行一次无返回值的数据删除,必须用到下面哪些对象? ( ) A.SqlConnectionB.SqlDataAdapterC.SqlCommandD.SqlDataReader 七、在ADO.NET中,对于Command对象的ExecuteNonQuery()方法和ExecuteReader()方法,下面叙述错误的是( ) A.insert、update、delete等操作的Sql语句主要用ExecuteNonQuery()方法来执行; B.ExecuteNonQuery()方法返回执行Sql语句所影响的行数。 C.Select操作的Sql语句只能由ExecuteReader()方法来执行; D.ExecuteReader()方法返回一个DataReder对象; 八、ASP.NET有多种维护状态的技术,以下哪种是保存在客户端的?( ) A.VIEWSTATEB.SESSIONC.APPLICATIOND.数据CACHE 九、Cookies的默认生命周期有多长? ( ) A.20分钟B.30分钟C. 一天D.随浏览器的关闭而失效 十、int[][] myArray=new int[3][]{ new int[3]{ 5, 6, 2 }, new int[5]{ 6, 9, 7, 8, 3 }, new int[2]{ 3, 2 }}; myArray[2][2]的值是( ) A.9B.2C.6D.越界 十一、要为做了输出缓存的页面实现即时判断用户IP来路,可在以下哪种事件中实现? ( ) A.Page.InitB.HttpApplication.BeginRequest C.Page.LoadD.以上都不是 十二、下面哪个SQL语句完全正确( ) A.Select count(*) from (select top 10 * from table order by bb) tb group by cc B.update set bb = bb + 1 from table C.Select count(*) from (select distinct * from table) tb group by cc D.delete * from table 十三、为了实现a.aspx的URL重写,下面哪个正则表达式替换可以实现?( ) A. Regex.Replace(sUrl, @“/(\d+).aspx”, “a.aspx?ID=$0”, RegexOptions.IgnoreCase) B. Regex.Replace(sUrl, @“/(\d+).aspx”, “/a.aspx?ID=$0”, RegexOptions.IgnoreCase) C. Regex.Replace(sUrl, @“/(\d+).aspx”, “a.aspx?ID=$1”, RegexOptions.IgnoreCase) D. Regex.Replace(sUrl, @“/(\d+).aspx”, “/a.aspx?ID=$1”, RegexOptions.IgnoreCase) 十四、下面javascript代码的输出结果是( ) var aa = new Array(1, 2, 4, 5, 3, 6); var c = 0; for (var i = 0; i < aa.length; ++i){ c += aa.pop(); } document.write(c); 提示:Array.pop()函数将数组内最后一个元素移除并返回该元素 A.7 B.14 C.21 D.以上皆不正确 填空题(共4题): 一、C#中判断整型变量k是否偶数的语句: 二、有这样的枚举定义:public enum TrainType{ 空调, 快速, 新型, 卧铺 },为实现它的按位组合,你会分别赋予它们什么值?请用逗号按顺序分隔开 三、C#中为了防止非本程序集的代码访问,可以用什么关键字修饰类或者类成员? 四、为了将table表内bb(datetime类型)字段的数据按年月降序输出,对应的SQL语句为 选择题答案: 1.B,2.D,3.C,4.BC,5.B,6.AC,7.C,8.A,9.D,10.D,11.B,12.AC,13.D,14.B 填空题答案: 1.(k & 1) == 0 或 k % 2 == 0 2.1,2,4,8(答案不定,看情况) 3.internal 4.select * from table order by year(bb) desc, month(bb) desc 1.new有几种用法 第一种:new Class(); 第二种:覆盖方法 public new XXXX(){} 第三种:new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。 2.如何把一个array复制到arrayList里 foreach( object o in array )arrayList.Add(o); 3.datagrid.datasouse可以连接什么数据源 [dataset,datatable,dataview] dataset,datatable,dataview , IList 4.概述反射和序列化 反射:程序集包含模块,而模块包含类型,类型又包含成员。反射则提供了封装程序集、模块和类型的对象。您可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型。然后,可以调用类型的方法或访问其字段和属性 序列化:序列化是将对象转换为容易传输的格式的过程。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象。在另一端,反序列化将从该流重新构造对象。 5.概述o/r mapping 的原理 利用反射,配置 将类于数据库表映射 6.类成员有( )种可访问形式 可访问形式?不懂。 可访问性:public ,protected ,private,internal 7.用sealed修饰的类有什么特点 sealed 修饰符用于防止从所修饰的类派生出其它类。如果一个密封类被指定为其他类的基类,则会发生编译时错误。 密封类不能同时为抽象类。 sealed 修饰符主要用于防止非有意的派生,但是它还能促使某些运行时优化。具体说来,由于密封类永远不会有任何派生类,所以对密封类的实例的虚拟函数成员的调用可以转换为非虚拟调用来处理。 8.列举ADO.NET中的五个主要对象,并简单描述 connection,command,dataReader,trans,dataset ... 9.执行下面代码后: String strTemp ="abcdefg 某某某"; Int i System.Text.Encoding.Default.GetBytes(strTemp).Length; Int j = strTemp.Length; 问:i=(14 ) ;j=(11 ) i=(14 ) ;j=(11 ) 中文两个字节 10.C#中,string str = null 与 string str ="",请尽量用文字说明区别。(要点:说明详细的内存空间分配) string str ="" 分配空间 11.详述.NET里class和struct的异同! class:放在 ? struct放在? struct值传递 类与结构有很多相似之处:结构可以实现接口,并且可以具有与类相同的成员类型。然而,结构在几个重要方面不同于类:结构为值类型而不是引用类型,并且结构不支持继承。结构的值存储在“在堆栈上”或“内联”。细心的程序员有时可以通过聪明地使用结构来增强性能。 12.概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。 远程逻辑调用,remoing接口只能用在.net中 13.什么是code-behind技术 aspx and cs 14.概述三层结构体系 web/business/dataaccess 15.asp.net如何实现MVC模式,举例说明! web/business/dataaccess ---------------------------------------------------------------------------------------------------------- 1.面向对象的思想主要包括什么? 答:这个题范围太广,不知道说什么. 2.什么是ASP.net中的用户控件 答:用户控件就是.ascx扩展名的东西喽,可以拖到不同的页面中调用,以节省代码.比如登陆可能在多个页面上有,就可以做成用户控件,但是有一个问题就是用户控件拖到不同级别的目录下后里面的图片等的相对路径会变得不准确,需要自已写方法调整. 3.什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释? 答:装箱就是把值类型转成引用类型,从MS IL角度看好像是boxing,没记错的话是把值从堆栈转到堆中.拆箱相反,重载就是指一个方法名同,参数个数不同,返回值可以相同的方法.CLR是通用语言运行时,其它的不清楚. 4.列举一下你所了解的XML技术及其应用 答:XML可是好东西,保存配置,站与站之间的交流,WEB SERVICE都要用它. 5.值类型和引用类型的区别?写出C#的样例代码。 答:结构是值类型,类是引用类型,所以传结构就是值类型的应用啦,传对象或类就是引用类型的,这个不用多写了吧. 6.ADO.net中常用的对象有哪些?分别描述一下。 答:connection command sqladapter dataset datatable dataview等等.写不完了. 7.如何理解委托? 答:据说相当于函数指针,定义了委托就可以在不调用原方法名称的情况下调用那个方法. msdn2005中是这样解释的: 委托具有以下特点: 委托类似于 C++ 函数指针,但它是类型安全的。 委托允许将方法作为参数进行传递。 委托可用于定义回调方法。 委托可以链接在一起;例如,可以对一个事件调用多个方法。 方法不需要与委托签名精确匹配。有关更多信息,请参见协变和逆变。 C# 2.0 版引入了匿名方法的概念,此类方法允许将代码块作为参数传递,以代替单独定义的方法。 8.C#中的接口和类有什么异同。 答:这个异同可多了,要说清楚还真不容易. 9.。net中读写数据库需要用到哪些类?他们的作用 答:这个类自已可以写的啊,你是指基类吗?那configuration,sqlconnection,sqlcommand等都要用到. 10.UDP连接和TCP连接的异同。 答:前者只管传,不管数据到不到,无须建立连接.后者保证传输的数据准确,须要连结. 11.ASP.net的身份验证方式有哪些?分别是什么原理? 答:form认证,windows集成认证等,原理不清楚. 12.进程和线程分别怎么理解? 答:进程是老子,线程是儿子,没有老子就没有儿子,一个老子可以有多个儿子.一个儿子可以成为别人的儿子,一个老子也可以为别的老子生儿子. 13.什么是code-Behind技术。 答:代码分离,这是个明智的东西,像ASP这样混成一堆很不爽.或者可以理解成HTML代码写在前台,C#代码写在后台.当然前台也有脚本,类的调用等,其实写在一起也是可以的. 14.活动目录的作用。 答:这个不明白.请明白的补充一下. 15..net中读写XML的类都归属于哪些命名空间? 答:System.Xml 我自已写的就不一定了,嘿嘿. 16.解释一下UDDI、WSDL的意义及其作用。 答:什么东西? 17.什么是SOAP,有哪些应用。 答:SOAP(Simple Object Access Protocol )简单对象访问协议是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于XML的协议。使用SOAP,不用考虑任何特定的传输协议(最常用的还是HTTP协议),可以允许任何类型的对象或代码,在任何平台上,以任何一直语言相互通信。这种相互通信采用的是XML格式的消息,具体请看:http://playist.blogchina.com/2521621.html 18.如何部署一个ASP.net页面。 答:随便啦,想直接上传就直接上传,想打包成EXE就打包,看个人喜好. 19.如何理解.net中的垃圾回收机制。 答:GC?对象创建了总要清除啊,不然内存哪够用?

110,545

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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