使用 linq 从动态 SQL 查询中检索和打印数据

Zer*_*vin 5 c# sql linq

我有一些现有代码,使用 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)

tva*_*son 1

我不认为迁移到 LINQ 有何价值。LINQ 的优点在于您可以使用域对象的语言而不是 T-SQL 来编写查询。在您的情况下,您只想接受实际的 SQL 命令。似乎需要更多的工作来解构该命令,将其转换为 LINQ(使用反射来识别数据上下文中的相应表),然后执行查询仅打印出结果对象的属性。