浅谈VB.NET DataRowView

开发 后端
这里介绍VB.NET DataRowView类是数据行的包装,它被多个Windows窗体控件使用。它使得显示与控件中的数据行相关的数据更加容易。

本文向大家介绍VB.NET DataRowView,可能好多人还不了解VB.NET DataRowView,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。

Windows窗体中的数据绑定列表框和组合框很节省时间。典型的代码如下(假定已经建立了SqlDataAdapter或者其它部件获取数据):

  1. Dim ds As New DataSet()  
  2. SqlDataAdapter1.Fill(ds, "Customers")  
  3. ListBox1.DataSource = ds.Tables("Customers")  
  4. ListBox1.DisplayMember = "CompanyName" 
  5. ListBox1.ValueMember = "CustomerID" 

在这种情况下,代码使用Northwind数据库的顾客记录工作。DisplayMember属性设置为你希望用户在列表框中看到的记录字段,它是 customers表的CompanyName.通常ValueMember属性设置为数据表中的一个键字段,对于customer来说是 CustomerID.一旦用户选择了列表框中的一行,很容易使用列表框的SelectedValue属性获得键字段:

MsgBox(ListBox1.SelectedValue)

但是有可能需要一个与被选择项相关的整个数据行对象的引用。例如,如果被选择的行需要被删除,就不知道键了。你需要一个数据行的引用以使用Delete方法。

典型的VB开发者通常这样想:"我已经得到了该行的键了,我将编写一些逻辑来查找使用该键的行".这样可以实现,但是有更好的实现方法。可以使用一行代码获取与列表框中选项关联的数据行:

  1. Dim dr As DataRow = CType(ListBox1.SelectedItem, DataRowView)Row 

通常该逻辑不会凭直觉出现,即使对经验丰富的开发者。为了解释这是怎样实现的,我把上面的一行拆成几行,下面的代码与上面代码的功能相同:

  1. Dim drv As DataRowView  
  2. drv = CType(ListBox1.SelectedItem, DataRowView)  
  3. Dim dr As DataRow  
  4. dr = drv.Row 

VB.NET DataRowView类是数据行的包装,它被多个Windows窗体控件使用。它使得显示与控件中的数据行相关的数据更加容易。当列表框被数据绑定到数据表时(假定列表框中的有些行当前被选定了),列表框的SelectedItem属性保存了一个VB.NET DataRowView对象。

这意味着我们能把列表框的SelectedItem属性转换到VB.NET DataRowView对象,这就是上面代码中的第二行实现的。接着VB.NET DataRowView暴露一个Row属性,它指向被包装的数据行。上面的代码声明了一个数据行并设置了Row属性。

转换对象的类型以访问它的接口的技术在VB 6.0中不是经常使用,但是在VB .NET中这是经常的。有了上面的例子后,大多数有经验的开发者迅速跟上了这种技术。

数据行的引用(dr)可用于用任何方式维护行。访问数据行中的任何特定字段是可行的。行中的数据可以被改变,能使数据行的Delete方法把该行标识为删除,或者从数据表的行集合中删除该行。下面的代码标识删除了一行:

dr.Delete()

使用主键(由ListBox.SelectedValue返回)查找下层数据行的方法需要很多代码,要花很长时间,执行起来更慢。对于刚开始使用VB .NET的程序员来说花几个小时编码是很正常的。理解上面的技术节约了很多时间,更简单、容易维护代码。

【编辑推荐】

  1. 简单描述VB.NET散列函数
  2. 详细分析VB.NET读写文本文件
  3. VB.NET GroupBox控件学习经验
  4. 概括VB.NET DomainUpDown控件
  5. VB.NET编码算法学习笔记
责任编辑:佚名 来源: IT168
相关推荐

2009-10-20 09:39:04

VB.NET Butt

2009-10-28 10:31:23

VB.NET Impl

2009-10-13 11:22:46

VB.NET调用Web

2009-10-12 13:32:58

VB.NET线程构造器

2009-10-16 10:14:26

VB.NET使用Fil

2010-01-22 15:56:03

VB.NET获取当前U

2009-10-19 11:28:42

VB.NET语言.NET开发语言

2010-01-21 17:23:05

VB.NET Radi

2009-06-29 10:50:18

VB.NET面向对象能力

2010-01-21 15:10:37

VB.NET静态托盘程

2009-06-23 11:49:22

跨进程消息钩子VB.NET

2009-10-20 14:03:48

VB.NET数组声明VB.NET数组初始化

2010-01-22 13:08:50

VB.NET创建数组

2009-10-26 17:07:17

VB.NET UNDO

2010-01-22 11:15:50

VB.NET固定值变量

2011-06-17 11:05:22

VB.NET

2009-06-24 15:45:32

VB.NET

2009-10-29 14:02:24

VB和VB.NET比较

2009-10-20 14:21:55

VB.NET fnSi

2009-11-02 17:12:01

VB和VB.NET
点赞
收藏

51CTO技术栈公众号