c# DataTable 选择带 Int32 的通配符

Posted

技术标签:

【中文标题】c# DataTable 选择带 Int32 的通配符【英文标题】:c# DataTable Select Wildcard with Int32 【发布时间】:2012-03-15 00:06:50 【问题描述】:

如果列的数据类型是Int32,是否可以在DataTable.Select(filter) 调用中使用通配符?

DataTable table = new DataTable();
DataColumn column = new DataColumn("Name", typeof(String));
DataColumn column = new DataColumn("Age", typeof(Int32));
table.Select("Name like 'b%'); // Works
table.Select("Age like '3%'); // Does NOT work.

这实际上在mysql 中有效,所以我只是想知道它是否可能在DataTable 中。

【问题讨论】:

【参考方案1】:

可以,但通配符使用星号而不是百分号

数据表选择语句的语法与数据列表达式的语法相同 - 请参阅 http://msdn.microsoft.com/en-us/library/system.data.datacolumn.expression.aspx 了解所有支持的语法选项

【讨论】:

* 和 % 都应该做同样的事情 - 请参阅我的答案中的链接以获取有效表达式 @PinnyM:伟大的思想,我也包括了链接。你说得对,两者都应该支持。出于某种原因,我只看到了 c# 中使用的星号【参考方案2】:

您应该能够转换为字符串,然后使用通配符:

table.Select("Convert(Age, 'System.String') like '3%');

请参阅http://msdn.microsoft.com/en-us/library/system.data.datacolumn.expression.aspx 了解有效表达式。

【讨论】:

以上是关于c# DataTable 选择带 Int32 的通配符的主要内容,如果未能解决你的问题,请参考以下文章

C# 使用列中的算术运算符通过字符串查询 DataTable

c# 中DataTable带条件的GroupBy写法怎么写?

C# 获取datatable某一列的值

C# DataTable详解

C# DataTable 详解

C# - Math.Sqrt() 返回小数