我熟悉.NET和SQL.现在我正在看新的LINQ,它看起来就像一个光标.我理解易用性等,但如果我使用foreach循环执行LINQ-to-SQL查询,我只是使用数据库游标吗?或者在幕后LINQ收集所有数据并一次一行地将它提供给我的程序的某些魔术?
不,它不是SQL意义上的游标.它不会一次迭代数据库中的行.相反,它使用您指定的条件动态构造查询.它会延迟查询的执行,直到需要第一个数据,然后对数据库执行查询.根据您使用数据的方式,可以为您缓冲数据,以便您可以逐行迭代它,或者如果您使用扩展方法获取列表,数组等,它可以将整个行集作为集合返回然而,就数据库而言,它只是执行一个SQL语句.