网上关于这方面的问题比较还是糊涂看得比较头疼---THC视频中也承认没有找到原因,不知道后来找到没有,不过天轰穿讲的另一个方法,我头大的狠—--也没有搞明白,主要是懒得打代码^^
VS2005中使用强类型DataSet简化开发
这个文章按照步骤下来还是更新数据出现的错误,到底错在哪里呢?
注意了:
ObjectDataSource“ObjectDataSource1”未能找到带参数的非泛型方法“UpdateQuery”: tttthhh, abc, original_id。
original_id----这个是主要问题。(我的数据库中表名字为name,主键名字为id,然后就是tttthhh,abc我的表就这么简单)
下面我们就一步步详细修改:主要步骤文字引用网上的)这个问题搞不清的朋友请重新照着一步一步的执行:
首先新建立一个Web网站项目,在[解决方案资源管理器]→[添加新项] →[数据集],命名为Authors.xsd,由于强类型DataSet需要放到App_Code目录,如果此时项目文件中没有App_Code目录,IDE会提示是否创建,我们选择"是"即可。
此时IDE会自动打开我们刚才建立好的Authors.xsd文件,并且开始运行TableAdapter配置向导,如果Web.Config没有数据库连结字符串,此时我们需要新建立一个连接:选择[新建连结] →[Microsoft SQL Server] →[选择系统自带的pubs数据库] →[将新建立的连结字符串保存到应用程序配置文件中]。
在接下来的选择命令类型的时候,IDE出来三个选项来供用户选择访问呢数据库的形式:
1、 使用SQL语句,如果是单个表,向导可以自动生成 Insert,Update和Delete语句。本例子也是使用的这种方法。
2、 创建新的存储过程。同样如果是单个表,向导可以自动生成 Insert,Update和Delete语句。
3、 使用现有存储过程。需要为每一个命令选择相应的现有存储过程。
我们这里选择[使用SQL语句] →[查询生成器] →[authors表,选择所有列],此时查询生成器会自动给我们生成 SQL语句(SELECT authors.* FROM authors)。[高级选项],可以选择是否生成Insert,Update和Delete语句,使用开放式并发来防止并发冲突,刷新数据表,用来验证 Insert和Update语句,为了能够更清晰的介绍使用方法,我们这里全部都不选择,而让我们以后根据需要自行添加。[选择要生成的方法] ,我们只需要使用[返回DataTable],其余的选项的对号去掉。
此时创建向导会自动给我们生成"Select语句","数据表的映射",以及"Get方法"。我们创建的过程就结束了。这是我们发现DataSet.xsd会自动生成一个authors表和一个包含Get方法的数据集authorsTableAdapter。
同样,在我们建立好的数据表[authorsTableAdapter]右键→添加查询,参照上边的方法生成DeleteQuery(删除),InsertQuery(增加),UpdateQuery(更新)、SelectDetail(返回详细结果,使用Select(返回行)选项,生成一个只包括一条数据的数据集----—注意: VS2005做不起来,所以这个步骤没做) 以及ScalarQuery(Select(返回单个值)返回数据统计)。
以下是生成的SQL语句,需要手工修改成自己需要的代码:
DeleteQuery:DELETE FROM [authors] WHERE ([au_id] = @Original_au_id)
InsertQuery:INSERT into authors (au_lname,au_fname,phone,address,city,state,zip,contract) values (@au_lname,@au_fname,@phone,@address,@city,@state,@zip,@contract)
UpdateQuery :UPDATE authors set au_lname=@au_lname,au_fname=@au_fname,phone=@phone,
address=@address,city=@city,state=@state,zip=@zip,contract=@contract where au_id=@au_id
SelectDetail:SELECT authors.* FROM authors where au_id=@au_id //这个SelectDetai代码根本没用,所以直接跳过,不用这个步骤了,其实系统默认
ScalarQuery :SELECT COUNT(*) FROM authors
打开Default.aspx,并添加一个GridView控件,并且添加一个ObjectDataSource控件,配置ObjecctDataSource的数据源,此时我们会发现在配置的时候系统已经认出来我们刚才建立的强类型DataSet了,[选择业务对象] →[authorsTableAdapters.authorstableAdapter] →[定义数据方法]分别选择Select,Update,Insert,Delete的方法,即我们刚才建立的DeleteQuery,InsertQuery,UpdateQuery,SelectDetail,ScalarQuery和系统生成的GetDate]。此时配置ObejctDataSource就完工了。
上面除了SelectDetai 没做之外,我都做了,最后执行起来还是错,是因为上面的updatequery代码少了东西:
-----------------------------------------------------------------------
UpdateQuery :UPDATE authors set au_lname=@au_lname,au_fname=@au_fname,phone=@phone,
address=@address,city=@city,state=@state,zip=@zip,contract=@contract where au_id=@au_id
------------------------------------------------------------------------------------------------------------------
where au_id=@au_id 应该改成 WHERE (au_id = @original_au_id)就行了
大功完成,基本上什么都不用动就改下UpdateQuery语句代码主键:
我的UpdateQuery在sql系统默认语句中 where后面 是“(id = @ id)”
所以只要改成(id = @original_id)就行了。
如果你的主键名字为X,那么(X = @original_X)改成这样就行了。