一起谈.NET技术,在ASP.NET 2.0中数据绑定的实现方法

简介: 1、为什么ASP.NET 2.0中的数据绑定控件不需要写代码就能完成更新、删除、新建等数据操作?   ASP.NET 1.x时,DataGrid等控件使用DataBinder.Eval(Container.DataItem,"ColumnName")这样的表达式可以将数据源中的数据绑定到控件上,但并不能在更新数据时自动将控件中的新值取出,更新回数据库。

1、为什么ASP.NET 2.0中的数据绑定控件不需要写代码就能完成更新、删除、新建等数据操作?

  ASP.NET 1.x时,DataGrid等控件使用DataBinder.Eval(Container.DataItem,"ColumnName")这样的表达式可以将数据源中的数据绑定到控件上,但并不能在更新数据时自动将控件中的新值取出,更新回数据库。所以ASP.NET 2.0中的数据绑定分为两种:单向数据绑定(即表达式或ReadOnly设为True的BoundField,只提供从数据源到控件的数据绑定)和双向数据绑定(,不但可以将数据从数据源绑定到控件,而且可以在操作数据时将控件中的数据提供给数据源控件),所以ASP.NET 2.0操作数据时就不需要写大量e.Item.FindControl()这样的代码了。

  2、在Update和Insert过程中,GridView/DetailsView/FormView是如何把值传递给数据源控件,以便数据源控件完成数据操作方法的调用的?

  更新时,GridView会提供两套值给数据源控件,一套新值,汇集所有ReadOnly不为True的列的值和模板中所有表达式的值,另一套旧的值,则从当前行对应的DataKey中获得(DataKey的值在绑定数据时就会被GridView保存到视图状态中),可以在GridView的Updating事件处理程序中看到这一特征。旧的那套值提供给数据源控件后,它的Key会被数据源控件根据OldValuesParameterFormatString重命名。比如,GridView中的DataKeyNames设为ProductID,数据源控件的OldValuesParameterFormatString为original_{0},那么GridView在更新时传给数据源控件的参数中就会有一个original_ProductID。

  新的那套值和老的那套值合起来要刚好和数据源控件需要的参数列表相匹配,不能多也不能少,这是初学者使用GridView更新数据时遇到最多的问题。

  实际使用过程中如果主键列对应的参数(比如,ProductID),没有像Strong named Dataset那样取名为original_ProductID,则需要更改数据源的OldValuesParameterFormatString,比如改成{0},这样才能和实现方法的参数对应起来。

  3、如何实现开放式并发?

  开放式并发的更新和删除语句会有一个很长的where 子句,比如:   

update Table1 set Column1 = @Column1 , 
Column2 = @Column2 
where ID = @original_ID 
and Column1 = @orignal_Column1 
and Column2 = @original_Column2;

  强类型数据集通过在高级选项上选中开放式并发的选钩可以自动生成这样的命令。根据我们第2点的论述,只需在GirdView的DatakeyNames属性中把所有的字段都加进去,这样就会自动的把旧的值放进老值集合中,满足数据源的要求。由此,我们可以理解为什么DataGrid的DataKeyField(单数)属性会被替换为DataKeyNames属性(复数)。

目录
相关文章
|
23天前
|
SQL 缓存 开发框架
分享一个 .NET EF6 应用二级缓存提高性能的方法
分享一个 .NET EF6 应用二级缓存提高性能的方法
|
23天前
|
开发框架 JSON .NET
ASP.NET Core 标识(Identity)框架系列(三):在 ASP.NET Core Web API 项目中使用标识(Identity)框架进行身份验证
ASP.NET Core 标识(Identity)框架系列(三):在 ASP.NET Core Web API 项目中使用标识(Identity)框架进行身份验证
|
14天前
|
开发框架 .NET 开发工具
【Azure 应用服务】App Service 的.NET Version选择为.NET6,是否可以同时支持运行ASP.NET V4.8的应用呢?
【Azure 应用服务】App Service 的.NET Version选择为.NET6,是否可以同时支持运行ASP.NET V4.8的应用呢?
|
23天前
|
程序员 数据库
分享 2 个 .NET EF 6 只更新某些字段的方法
分享 2 个 .NET EF 6 只更新某些字段的方法
|
23天前
|
数据库
分享一个 .NET EF 6 扩展 Where 的方法
分享一个 .NET EF 6 扩展 Where 的方法
|
23天前
|
开发框架 前端开发 算法
分享 .NET EF6 查询并返回树形结构数据的 2 个思路和具体实现方法
分享 .NET EF6 查询并返回树形结构数据的 2 个思路和具体实现方法
|
23天前
|
开发框架 中间件 .NET
分享 ASP.NET Core Web Api 中间件获取 Request Body 两个方法
分享 ASP.NET Core Web Api 中间件获取 Request Body 两个方法
|
23天前
|
开发框架 .NET 数据库连接
ASP.NET Core 标识(Identity)框架系列(一):如何使用 ASP.NET Core 标识(Identity)框架创建用户和角色?
ASP.NET Core 标识(Identity)框架系列(一):如何使用 ASP.NET Core 标识(Identity)框架创建用户和角色?
|
23天前
|
开发框架 .NET API
如何在 ASP.NET Core Web API 方法执行前后 “偷偷“ 作一些 “坏“ 事?初识 ActionFilterAttribute
如何在 ASP.NET Core Web API 方法执行前后 “偷偷“ 作一些 “坏“ 事?初识 ActionFilterAttribute
|
23天前
|
开发框架 前端开发 .NET
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写
Asp.net Webapi 的 Post 方法不能把参数加到 URL 中?试试这样写