20160122 DataView RowFilter语法
原文出自:http://www.csharp-examples.net/dataview-rowfilter/
DataView RowFilter语法(c#)
这个例子描述了DataView.RowFilter表达式的语法。它显示了如何正确构建表达式字符串(不„SQL注入”)转义字符的使用方法。
列名
如果一个列名包含这些特殊字符 ~ ( ) # \ / = > < + - * % & | ^ ' " [ ],你必须在列名上加上方括号[ ]。如果一个列名包含右括号 ]或反斜杠 \,用反斜杠转义(\]或 \\).
(c#)
文字
字符型(String):使用单引号包裹’’。如果字符串包含单引号’,使用两个单引号。
(c#)
dataView.RowFilter
= String.Format("Name = '{0}'", "John 'A'".Replace("'", "''"));
数值型:不需要使用特殊符号包裹。的值应该是一样的结果 int.ToString()或 float.ToString()方法不变或英语文化。
(c#)
dataView.RowFilter
= String.Format(CultureInfo.InvariantCulture.NumberFormat,"Price = {0}", 1199.9f);
日期型:使用井号字符包裹 # #。日期格式是一样的结果 DateTime.ToString()方法不变或英语文化。
(c#)
dataView.RowFilter
= String.Format(CultureInfo.InvariantCulture.DateTimeFormat, "Date = #{0}#", newDateTime(, , , , , ));
或者你可以使用单引号包裹' '。这意味着您可以使用数字或日期时间值的字符串值。在这种情况下,当前英文用于将字符串。
(c#)
dataView.RowFilter
= "Price = '1199.90'"// if current culture is English dataView.RowFilter = "Price = '1199,90'"// if current culture is German
比较运算符
平等,不等,小于,大于的运营商用于只包括适合比较表达式的值。您可以使用这些操作符 = <> < <= > >=.
注意:字符串比较是与文化相关的,它使用的CultureInfoDataTable.Locale房地产相关的表(dataView.Table.Locale)。如果没有显式地设置属性,它的默认值是数据集。地区(及其默认值是当前系统文化Thread.CurrentThread.CurrentCulture)。
(c#)
运算符IN:是用来从列表中只包含值。您可以使用操作员对所有数据类型,如数字或字符串。
(c#)
dataView.RowFilter
= "Id NOT IN (1, 2, 3)"// values not from the list
运算符LIKE:是用来只包含值与通配符匹配一个模式。通配符是 *或 %,它可以在一个模式的开始 '*value',最后'value*',或者在两侧 '*value*'。通配符在中间 是不允许的'va*lue'。
(c#)
dataView.RowFilter
= "Name NOT LIKE 'j*'"// values that don't start with 'j'
如果包含这些特殊字符 * % [ ],这些字符必须在括号中 [ ]像这样 [*], [%], [[]或[]].
(c#)
下面的方法转义一个文本的使用的例子。
(c#)
sb.Append(c);
}
return sb.ToString();
}
(c#)
//
select all that starts with the value string (in this case with "*")string value = "*"; // the dataView.RowFilter will be: "Name LIKE '[*]*'" dataView.RowFilter = String.Format("Name LIKE '{0}*'"EscapeLikeValue(value));
布尔操作符
布尔操作符 AND, OR和 NOT用于连接表达式。运算符 NOT它优先于运算符AND优先于运算符OR。
(c#)
算术和字符串操作符
算术运算符是加法 +、减 -、乘 *、除 /和模量 %.
(c#)
还有一个字符串运算符连接 +.
亲子关系引用
但事情表可以使用父表达式中引用的列名称 Parent.前缀。Acolumn子表中可以使用孩子列名称引用 Child.前缀。
对孩子的引用列必须在一个聚合函数,因为孩子的关系可能返回多个行。例如表达 SUM(Child.Price)返回的所有价格在parenttable行相关的子表。
如果一个表有一个以上的孩子关系,前缀名称必须包含关系。例如表达Child(OrdersToItemsRelation).Price引用列价格在子表中使用关系叫OrdersToItemsRe副调制。
聚合函数
有支持的聚合函数 SUM, COUNT, MIN, MAX, AVG(平均) STDEV(统计标准偏差) VAR(统计方差)。
这个例子展示了singletable聚合函数执行。
(c#)
下面的例子显示了聚合函数对两个表进行亲子关系。假设有表订单和项目与亲子关系。
(c#)
功能
也有支持以下功能。详细描述可以在这里找到DataColumn.Ex压力.
CONVERT——将特定的表达式来指定的。净FrameworktypeLEN——得到一个字符串的长度ISNULL——检查表达式并返回检查表达式或replacementvalueIIF——得到两个值之一取决于逻辑表达式的结果TRIM——删除所有前导和尾随空白字符\ r、\ n \ t,‚”SUBSTRING——指定长度的子串,在thestring开始在指定点
20160122 DataView RowFilter语法的更多相关文章
- DataView RowFilter Syntax [C#]
RowFilter语法 private void btnEnquiry_Click(object sender, EventArgs e) { string filterExpression = st ...
- DataView.RowFilter筛选DataTable中的数据
//定义一个DataView ,得到一个全部职员的视图DataView dataView1 = DbHelperSQL.QueryDataView(sql); //过滤得到一个只显示男职员的视图 da ...
- DataView RowFilter
DataView类用来表示定制的DataTable的视图. DataTable和DataView的关系是遵循著名的设计模式--文档/视图模式,其中DataTable是文档,而Dataview是视图. ...
- .NET中的视图和过滤器 (DefaultView和RowFilter)
NET中的视图和过滤器 (DefaultView和RowFilter) ADO.NET中有一层对象,用来创建任意数据源的抽象模型.其中包括DataSet,DataTable,DataRow,DataV ...
- [转载]DataView详解
表示用于排序.筛选.搜索.编辑和导航的 DataTable 的可绑定数据的自定义视图. DataView的功能类似于数据库的视图,他是数据源DataTable的封装对象,可以对数据源进行排序.搜索.过 ...
- .net窗体程序的基础知识及详细笔记
第一章:初识Windows程序 1.1:第一个wondows程序 1.1.1:认识windows程序 Form1.cs:窗体文件:程序对窗体编写的代码一般都存放在这个文件(还有拖动控件时的操作和布局, ...
- C# 对Datatable排序
一,在C#中要对Datatable排序,可使用DefaultView的Sort方法.先获取Datatable的DefaultView,然后设置 得到的Dataview的sort属性,最后用视图的ToT ...
- 浅谈DevExpress<二>:设计一个完整界面(2)
下面来把剩下的工作做完,换肤功能昨天已近讨论过,今天就不重复了.首先建立三个全局变量,一个存放文件路径,一个存放数据,一个存放过滤条件. string DBFileName; DataView dat ...
- Winform带dataGridview的Combox控件
调用控件: public partial class Form1 : Form { public Form1() { InitializeComponent(); //---------------- ...
随机推荐
- [19/05/16-星期四] HTML_body标签(表格标签)
一.概念 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...
- css定位:相对定位、绝对定位、固定定位的区别与特性
css定位:相对定位.绝对定位.固定定位的区别与特性 原文地址:http://www.qingzhouquanzi.com/106.html css定位常用的有以下三种: 使用了定位的共同特性: 这三 ...
- java枚举详解
枚举的本质是类,枚举是用来构建常量数据结构的模板(初学者可以以此方式理解: public static final X=xxx),枚举的使用增强了程序的健壮性,在引用一个不存在的枚举值的时候,编译器会 ...
- Java static关键字的重新思考
上完Java课,虽然也写了不少的Java代码,但是一直有不少的疑惑,而static关键字一直困惑着我很久,今天无意探究竟,上知乎再仔细查了一下,发现了这个话题的优秀答案https://www.zhih ...
- Viewer.js – 强大的JS/jQuery图片查看器
简介 Viewer.js 是一款强大的图片查看器,像门户网站一般都会有各自的图片查看器,如果您正需要一款强大的图片查看器,也许 Viewer.js 是一个很好的选择.Viewer.js 有以下特点: ...
- 给当当同学的random data
m**o 00'57"32街**o 00'52"23c**6 00'44"15斗**6 00'57"58n**5 00'32"04s**p 00'51 ...
- Docker实战部署应用——Redis
Redis 部署 拉取Redis镜像 docker pull redis 创建Redis容器 docker run -id --name=sun_redis -p 6379:6379 redis 客户 ...
- CentOS7系统局域网内配置本地yum源解决cannot find a valid baseurl for repo
一. 问题详情 因为服务器无法连接外网,所有直接用yum安装某些功能将受到影响,报错如下: Error: Cannot find a valid baseurl for repo: base ...
- 2-基于6U VPX的双TMS320C6678+Xilinx FPGA K7 XC7K420T的图像信号处理板
基于6U VPX的双TMS320C6678+Xilinx FPGA K7 XC7K420T的图像信号处理板 综合图像处理硬件平台包括图像信号处理板2块,视频处理板1块,主控板1块,电源板1块,VPX背 ...
- HDU-3810 超大容量01背包
题意:有n堆野兽,每堆野兽屠杀完完需要花费ti时间,可以增加金钱gi,敌法师有瞬移技能,可以从某堆野兽移到另一堆野兽,题目有给定从哪堆可以移到哪堆.最后问在满足打的金钱多余m的情况下的最少时间.数据范 ...