vb.net环形状态 vbnet process( 二 )


我最喜欢用的是IIF(),它按照逻辑表达式的值有一到两个值 。IIF是IF-THEN-ELSE语句的紧凑表达 。语法如下:
IIF(expression, if_true, if_false)
通 过该函数,可以建立非常复杂的过滤字符串 。例如,假定你从SQL Server的Northwind数据库中取得Employees表,下列表达式可以选出那些employeeID小于6且lastname为偶数个字符 和employeeID大于6且lastname为奇数个字符的员工 。
IIF(employeeID6, Len(lastname) %2 =0, Len(lastname) %2 0)
预排视图
在上面的举例中,datagrid必须负责预排视图中的数据行,以便刷新用户界面 。这个自动机制是.NET
数据绑定的产物 。Datagrid是通过DataSource属性来获取数据的数据绑定控件 。DataView是一个可数据绑定的类,可构建DataSource属性的内容 。
如果你想使用datagrid之外的另一个控件,应该怎么办呢?又如果你不想使用自动数据绑定呢?应该怎样预排视图中所选的数据行呢?
DataView的Table属性指向相应的数据表,但DataTable并不保存过滤信息 。所以,预排表中的数据注定是不可行的 。虽然DataTable和DataView是紧密相联的,但它们各自保持独立,并执行独立的功能 。
以下Visual Basic .NET代码段显示了如何遍历视图中所有的数据行,并加入到listbox中 。
Dim dv As New DataView()
dv = ds.Tables("Employees").DefaultView
dv.RowFilter = "employeeid 5"
ListBox1.Items.Clear()
Dim buf As String
Dim dr As DataRowView
For Each dr In dv
buf = ""
buf = dr("lastname").ToString() ", "dr("firstName").ToString()
ListBox1.Items.Add(buf)
Next
正如前面说提到的,DataView是可枚举的类,因此你可以安全的将它传给For..Each语句 。Count属性存储了视图中数据行数,以便在For..Next循环中使用 。
要访问视图中某一行,可以使用DataRowView类 。DataRowView可表示DataRow的视图,就像DataView表达DataTable定制的视图一样 。
总的来说,DataRow最多有四种状态:default,original , current和proposed 。这些状态由DataRowVersion枚举类型设置,由RowVersion属性表达 。
DataRow的视图只能是其中某一种状态 。
数据行的默认(default)版本只有当其列在构造时设定了默认值时才有 。而初始(original)版本是指在最后一次调用表的AcceptChanges后 , 从数剧源中得到数据行或快照 。当前(Current)版本是指当前的数据行,包括所有当时发生的更新 。Proposed状态只存在于调用BeginEdit和EndEdit的编辑过程中 。
可以通过访问DataRow相同的语法访问DataRowView 。这里最重要的属性叫Item 。
排序和其他便捷的特性
DataView支持Sort属性,可以用来对视图中的内容排序 。Sort由用逗号分隔的列名表达式进行排序 。通过在任何列名后加ASC或者DESC限定词,可以使得字段按照上升或者下降的顺序排列 。如果没有方向限定词 , 默认顺序为ASC 。
DataView是内存中的对象 , 所以排序在本地进行,无需调用数据库服务器 。
RowStateFilter是DataView另一有趣的属性 。它可以用任何预定义的标准来过滤DataTable中的内容 。下表中是DataViewRowState枚举类型的所有取值:
CurrentRows包括所有未更新的、新的和修改的数据行Deleted所有自上次调用AcceptChanges后删除的数据行ModifiedCurrent所有自上次调用AcceptChanges后修改过的数据行ModifiedOriginal所有自上次调用AcceptChanges后original版本的数据行New所有自上次调用AcceptChanges后新添加的行OriginalRows返回初始数据行,包含unchanged和deleted 的Unchanged所有未更新的数据行
如果要操作非连接的数据,所有更新都在对DataTable调用AcceptChanges后生效 。对单一行的更新在调用DataRow的AcceptChanges后生效 。类似的 , 这些更新可以通过调用DataTable或DataRow对象的RejectChanges来取消 。

推荐阅读