如果要选取的行并不能方便地通过算术或逻辑运算符表达,你可以使用IN操作符 。以下代码显示如何选取一个随机行:
dv.RowFilter = "employeeID IN (2,4,5)"
你也可以使用通配符*和%,它们同LIKE运算符一起使用时显得更有用 。它们都表示任意数量的字符,可以相互替代使用 。
请注意,如果在LIKE子句中已经有了*或%字符,你必须用方括号将其括起 , 以免歧义 。如果很不幸,字符串中方括号本身也存在了,那么它也必须用将本身括起 。这样,匹配语句会如下所示:
dv.RowFilter = "Description LIKE '[[]*[]]product[[]*[]]"
通配符只允许在过滤字符串的开头或结尾处使用,而不能在字符串中间出现 。例如,下列语句会产生运行时错误:
dv.RowFilter = "Description LIKE 'prod*ct"
字符串必须以单引号括起 , 而日期型必须以#符号括起 。字符型值可以使用小数点和科学计数法 。
RowFilter也支持聚合函数,如SUM, COUNT, MIN,MAX, and AVG 。如果表中没有数据行,那么函数将返回NULL 。
在介绍RowFilter表达式的最后,让我们讨论三个很便利的函数:Len,IIF和Substring 。
正如其名,Len()返回特定表达式的长度 。该表达式可以是一个列名,也可以是其他合法的表达式 。
Substring()返回指定的表达式自特定位置开始,特定长度的字符子串 。
我最喜欢用的是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之外的另一个控件,应该怎么办呢vb.net聚合函数?又如果你不想使用自动数据绑定呢?应该怎样预排视图中所选的数据行呢?
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的编辑过程中 。
推荐阅读
- 不开机怎么设置路由器密码,如何不用密码进入路由器设置
- redis数据订阅分发,redis 发布订阅会自己阻塞吗
- 如何成功营销论文,营销模式论文
- jQuery上传文件不成功,jq 上传文件
- 同名函数python python 同名函数
- 固态硬盘怎么保持寿命不变,固态硬盘怎样使用寿命更长
- 电脑代理ip如何设置在哪里,电脑代理ip如何设置在哪里查看
- 新人预告直播文案,直播预告文案写作技巧
- 最高分函数python 最高分函数怎么求