- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
基本上我正在尝试将以下 mssql 查询重现为 LINQ
SELECT DISTINCT [TABLENAME], [COLUMNNAME] FROM [DATATABLE]
我得到的最接近的是
Dim query = (From row As DataRow In ds.Tables("DATATABLE").Rows _
Select row("COLUMNNAME") ,row("TABLENAME").Distinct
当我执行上述操作时,我收到错误
Range variable name can be inferred only from a simple or qualified name with no arguments.
我有点期待它返回一个集合,然后我可以迭代该集合并为每个条目执行操作。也许是数据行集合?
作为一个完整的 LINQ 新手,我不确定我错过了什么。我尝试过各种变化
Select new with { row("COLUMNNAME") ,row("TABLENAME")}
并得到:
Anonymous type member name can be inferred only from a simple or qualified name with no arguments.
为了解决这个问题,我尝试过
Dim query = From r In ds.Tables("DATATABLE").AsEnumerable _
Select New String(1) {r("TABLENAME"), r("COLUMNNAME")} Distinct
但是它似乎并没有正确地完成不同的事情。
另外,有人知道有什么好的书籍/资源可以让你说得流利吗?
最佳答案
您开始在数据表对象上使用 LINQ,对 dt.AsEnumberable 运行查询,该查询返回 DataRow 对象的 IEnumerable 集合。
Dim query = From row As DataRow In ds.Tables("DATATABLE").AsEnumerable _
Select row("COLUMNNAME") ,row("TABLENAME")
您可能想说 row("COLUMNNAME").ToString()
等。查询最终将成为具有 2 个字符串属性的匿名类型的 IEnumerable;这就是你所追求的吗?您可能需要指定属性的名称;我认为编译器不会推断它们。
Dim query = From row As DataRow In ds.Tables("DATATABLE").AsEnumerable _
Select .ColumnName = row("COLUMNNAME"), .TableName = row("TABLENAME")
这假设在您使用 ADO 获取此数据集的原始 SQL 查询中,您确保结果是不同的。
其中一个关键是 Linq-to-SQL 和(通常称为 Linq-to-object 事件)LINQ-to-Dataset是两个截然不同的事情。在这两种情况下,您都会看到使用 LINQ,因此它经常会引起困惑。
是:
1 以与以往相同的旧方式获取数据表,使用数据适配器和连接等,最终得到传统的数据表对象。然后,您不再像以前那样迭代行,而是:
2 针对 dt.AsEnumerable
运行 linq 查询,它是数据行对象的 IEnumerable。
Linq-to-dataset 选择 (A) 不使用 Linq-to-SQL,而是使用传统的 ADO.NET,但随后 (B )一旦你有了数据表,就可以使用 LINQ(-to-object) 来检索/排列/过滤数据表中的数据,而不是我们 6 年来一直这样做的方式。我经常这样做。我喜欢常规的 ado sql(使用我开发的工具),但是 LINQ 很棒
是一个不同的野兽,在幕后发生着截然不同的事情。在 LINQ-To-SQL 中,您:
1 使用 Visual Studio 中的工具定义与您的数据库匹配的架构,这为您提供与您的架构匹配的简单实体对象。
2 您使用 db Context 编写 linq 查询,并获取这些实体作为结果返回。
在底层,.NET 在运行时将这些 LINQ 查询转换为 SQL 并将它们发送到数据库,然后将返回的数据转换为您在架构中定义的实体对象。
嗯,这是一个相当简短的摘要。要进一步了解这两个截然不同的事物,请查看:
LINQ-to-SQL
LINQ-to-Dataset
关于 LINQ 的一本很棒的书是 LINQ in Action 、我的法布里斯·玛格丽、史蒂夫·艾克特和吉姆·伍利(曼宁)。去实现它(梦想);去得到它(东西!正是您所追求的。非常好。 LINQ 并不是昙花一现,值得读一本书。在 .NET 中,有很多东西需要学习,但是花时间掌握 LINQ 是值得的。
关于vb.net - Linq to Datarow,选择多个不同的列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2654525/
我有几个问题。我是 Visual Basic 这个领域的新手,所以不要取笑我。 1.) VB.NET之间有什么区别和 VB ? 2.) 我需要为 Windows 开发基本的应用程序。(如记事本)我应该
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我是框架 3.5 的新手。我注意到,在创建 Web 内容表单时,除了 aspx.vb 页面之外,它还会创建一个 aspx.designer.vb 页面。谁能向我解释一下它们之间的区别以及它们的用途吗?
我只是想知道 VB.NET 和 VB 2010 是否相同。 我只是想知道。 最佳答案 VB 2010 是 VB.Net 的最新版本。 Microsoft 在 VB 2005 版本中删除了 VB 的“.
我是框架 3.5 的新手。我注意到,在创建 Web 内容表单时,除了 aspx.vb 页面之外,它还会创建一个 aspx.designer.vb 页面。谁能向我解释一下它们之间的区别以及它们的用途吗?
我正在尝试将 VB 函数移植到 VB.NET,但我无法使该函数正常工作并正确更新。 rFormat = Format(Format(Value, fmt), String$(Len(fmt), "@"
如何在VB中注释多行代码/代码块? 最佳答案 VB 在语言级别上没有这样的构造。它有使用撇号字符的单行注释: ' hello world ' this is a comment Rem this is
我正在使用我在 VB2005 中创建的表单在按下按钮时打开程序,然后在文本字段中显示进程 ID(再次按下按钮时)。当我运行它时,表单将打开程序 (Notepad.exe) 但当我单击按钮查看进程 ID
我正在尝试添加一个从 vb.net 创建的 dll,并且想将其导入到现有的 vb 6 项目中,但它给了我错误“无法添加对指定文件的引用”。 。有人知道如何解决这个问题吗? 最佳答案 需要遵循以下步骤:
我有一个数据 GridView 。右键单击它会显示一个上下文菜单,但它始终位于右上角。我想要它,以便菜单出现在用户右键单击的单元格上。它可能是单元格 1 或单元格 2 或其他。 谢谢福尔坎 最佳答案
我只是在 Visual Studio 2010 中使用 Visual Basic。有人知道我将如何制作“浏览文件夹(或文件)”按钮吗?我对 VB 真的很陌生,我只是在寻找一些简单的帮助:) 最佳答案
这次感到困惑... 最简单的代码行有时可能起作用,有时却没有。首先,我认为问题在于我试图读取DWORD的值,但是由于我可以从某些键读取DWORD值,所以这一定不是问题。现在的问题似乎是,如果 key
我的代码中有此方法: Private Sub Display() Received.AppendText(" - " & RXArray) End Sub 这两个调用之间有什么区别:
我正在创建一个宏程序来记录和回放鼠标和键盘输入。录制效果很好,鼠标播放也一样,但是我在播放键盘输入时遇到了麻烦——特别是在释放之前按住一个键几秒钟。这不等同于重复按键。这是我尝试过的: 技巧 1:Me
我最近刚刚了解了 VB.NET 中静态局部变量的使用,并想知道它在延迟加载属性中的潜在用途。 考虑以下示例代码。 Public Class Foo Implements IFoo End Clas
VB 有一个 C# 没有的特性,在项目级别导入命名空间(我的项目>引用>导入命名空间)。当新人在源代码控制之外检查项目时,我们的自定义导入不包括在内。这个 VB 特定的导入命名空间存储在哪里? 最佳答
我已将我的问题缩小到这个简单的案例,但似乎无法找到发生了什么: 我有两个表单,一个只有一个按钮,另一个是空的。 单击按钮时,form1 隐藏和显示 form2 出现时,form2隐藏,form1再次显
为什么下面的简单代码会失败?无论我使用 LinearGradientMode 的哪个值,这段代码总是用从左到右的渐变填充路径。 graphPath 是在别处创建的 GraphicPath 对象(基本上
我可以多快替换字符串中的字符? 所以这个问题的背景是这样的:我们有几个应用程序通过套接字相互通信并与客户端的应用程序通信。这些套接字消息包含不可打印的字符(例如 chr(0)),需要用预定的字符串(例
如何从任何文件中读取原始字节数组... Dim bytes() as Byte ..然后将该字节数组写回新文件? 我需要它作为一个字节数组来做一些处理。 我目前正在使用: 阅读 Dim fInfo
我是一名优秀的程序员,十分优秀!