DataTable AsEnumerable 匹配单个值
DataTable AsEnumerable matching a single value
假设我的查询 return 是一个数据表,它是一个电子邮件地址列表,一个名为 "email" 的 varchar 列;这些电子邮件被授权做某事。
jane@doe.com
mike@foo.com
donald@duck.com
当前登录用户是harry@houdini.com
。他没有被授权。他不在名单上
是否可以使用 Linq 和 return 布尔值 false
迭代数据行?
或 return 一个 null
或 Nothing
或空的对象?
本质上,我想知道
的Linq版本
Authorized = List.Contains( "harry@houdini.com")
我真的很想知道如何在 C# 和 VB 中做到这一点。
谢谢
Any
在这里可能更干净:
bool exists = dataTable.AsEnumerable()
.Any(r => "harry@houdini.com".Equals(r[0]));
您 可以 将列投影到字符串集合并使用 Contains
,但这里似乎有点过分了。
或者定义主键并在 DataRowCollection
上使用本机 Contains
方法:
dataTable.PrimaryKey = dataTable.Columns[0];
bool exists = dataTable.Rows.Contains("harry@houdini.com");
下面是 DataTable
的工作示例
在C#
DataTable dt = new DataTable();
dt.Columns.Add("emails");
dt.Rows.Add("jane@doe.com");
dt.Rows.Add("mike@foo.com");
dt.Rows.Add("donald@duck.com");
var authorized = dt.AsEnumerable().Any(s => s[0].Equals("mike@foo.com")); //returns True
var notAuthorized = dt.AsEnumerable().Any(s => s[0].Equals("harry@houdini.com")); //returns False
在VB
(在线转换)
Dim dt As DataTable = New DataTable
dt.Columns.Add("emails")
dt.Rows.Add("jane@doe.com")
dt.Rows.Add("mike@foo.com")
dt.Rows.Add("donald@duck.com")
Dim authorized As var = dt.AsEnumerable.Any(() => { },
s(0).Equals("mike@foo.com"))
Dim notAuthorized As var = dt.AsEnumerable.Any(() => { },
s(0).Equals("harry@houdini.com"))
假设我的查询 return 是一个数据表,它是一个电子邮件地址列表,一个名为 "email" 的 varchar 列;这些电子邮件被授权做某事。
jane@doe.com
mike@foo.com
donald@duck.com
当前登录用户是harry@houdini.com
。他没有被授权。他不在名单上
是否可以使用 Linq 和 return 布尔值 false
迭代数据行?
或 return 一个 null
或 Nothing
或空的对象?
本质上,我想知道
的Linq版本 Authorized = List.Contains( "harry@houdini.com")
我真的很想知道如何在 C# 和 VB 中做到这一点。
谢谢
Any
在这里可能更干净:
bool exists = dataTable.AsEnumerable()
.Any(r => "harry@houdini.com".Equals(r[0]));
您 可以 将列投影到字符串集合并使用 Contains
,但这里似乎有点过分了。
或者定义主键并在 DataRowCollection
上使用本机 Contains
方法:
dataTable.PrimaryKey = dataTable.Columns[0];
bool exists = dataTable.Rows.Contains("harry@houdini.com");
下面是 DataTable
的工作示例
在C#
DataTable dt = new DataTable();
dt.Columns.Add("emails");
dt.Rows.Add("jane@doe.com");
dt.Rows.Add("mike@foo.com");
dt.Rows.Add("donald@duck.com");
var authorized = dt.AsEnumerable().Any(s => s[0].Equals("mike@foo.com")); //returns True
var notAuthorized = dt.AsEnumerable().Any(s => s[0].Equals("harry@houdini.com")); //returns False
在VB
(在线转换)
Dim dt As DataTable = New DataTable
dt.Columns.Add("emails")
dt.Rows.Add("jane@doe.com")
dt.Rows.Add("mike@foo.com")
dt.Rows.Add("donald@duck.com")
Dim authorized As var = dt.AsEnumerable.Any(() => { },
s(0).Equals("mike@foo.com"))
Dim notAuthorized As var = dt.AsEnumerable.Any(() => { },
s(0).Equals("harry@houdini.com"))