我有一些现有代码,使用 ADO.NET 从数据库检索数据,我想将其转换为 linq。
该代码的作用是通过命令行接收 SQL 查询,执行它,返回行及其列名称,然后将它们打印到屏幕上。我想知道如何在 linq 中编写这段代码。
整个 sql 查询必须通过命令行给出,因为我想限制从中选择行的位置。这是我想要完成的唯一方法,所以除非你有一个可以这样工作的方法,否则我不能使用它。除了我自己之外,没有人可以访问该程序,因此安全性不是问题。
private static SqlConnection sqlConnection = new SqlConnection();
private static void OConnection()
{
sqlConnection = new SqlConnection();
sqlConnection.ConnectionString = MyConsoleApp.Properties.Settings.Default.ConnStr;
sqlConnection.Open();
}
Run Code Online (Sandbox Code Playgroud)
...
string query = Console.ReadLine();
OpenConn();
SqlCommand command = new SqlCommand(query, sqlConnection);
SqlDataReader reader = command.ExecuteReader();
if (reader != null)
{
while (reader.Read())
{
for (int i = 0; i < reader.FieldCount; i++)
{
Console.Write("| {0}: {1}", reader.GetName(i), reader.GetValue(i));
}
Console.WriteLine();
}
}
Run Code Online (Sandbox Code Playgroud)
我不认为迁移到 LINQ 有何价值。LINQ 的优点在于您可以使用域对象的语言而不是 T-SQL 来编写查询。在您的情况下,您只想接受实际的 SQL 命令。似乎需要更多的工作来解构该命令,将其转换为 LINQ(使用反射来识别数据上下文中的相应表),然后执行查询仅打印出结果对象的属性。
| 归档时间: |
|
| 查看次数: |
2287 次 |
| 最近记录: |