如何将 T-SQL 选择到 C# 变量中

本文关键字:变量 选择 T-SQL | 更新日期: 2023-09-27 18:36:43

我正在使用SQL Server 2008 R2和C# ASP.NET 4

我有一个名为myTable的简化表,包括列:Col1, Col2, Col3, Col4

CREATE TABLE [dbo].[myTable](
    [Col1] [int] NULL,
    [Col2] [int] NULL,
    [Col3] [nvarchar](50) NULL,
    [Col4] [int] NULL
) ON [PRIMARY]
GO
INSERT [dbo].[myTable] ([Col1], [Col2], [Col3], [Col4]) VALUES (0, 0, N'@', 0)
INSERT [dbo].[myTable] ([Col1], [Col2], [Col3], [Col4]) VALUES (1, 2, N'c', 4)
INSERT [dbo].[myTable] ([Col1], [Col2], [Col3], [Col4]) VALUES (11, 22, N'cc', 44)

(原始表格要宽得多)

如何将两列(或 20 或 200)列SELECT为 C# 变量或变量数组/列表,或任何其他有效或优于此类内容的内容:

object obj = new object();
string sql = "SELECT Col2, Col3 FROM myTable WHERE Col1=0";
using (SqlConnection conn = new SqlConnection(mySqlCalss.DatabaseConnectionString() ))
            {
                SqlCommand cmd = new SqlCommand(sql, conn);
                cmd.Connection.Open();
                obj = cmd.ExecuteNonQuery();
            }

在某种程度上,我可以使用以下内容:

int myVar1 = (int)ojb[0];
string myVar2 = (string)obj[1];

然后:

lblMyASPlable1.Text = myVar1.ToString();
lblMyASPlable2.Text = myVar2;

如何将 T-SQL 选择到 C# 变量中

您正在使用"ExecuteNonQuery",它按照它在锡上所说的去做,并且不像查询那样执行,即选择。尝试执行阅读器。

SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
    Console.WriteLine(String.Format("{0}", reader[0]));
}

使用读取DataReader查看数据读取器的实际应用

你需要SQLDataAdapter

DataTable table = new DataTable();
string sql = "SELECT Col2, Col3 FROM myTable WHERE Col1=0";
using (SqlConnection conn = new SqlConnection(mySqlCalss.DatabaseConnectionString() ))
{
   SqlCommand cmd = new SqlCommand(sql, conn);
   cmd.Connection.Open();
   SqlDataAdapter adapter = new SqlDataAdapter(cmd);
   adapter.Fill(table);                
}

int myVar1;
string myVar2;
if(table.Rows.Count>0)
{
  myVar1 = (int)table.Rows[0]["Col2"];
  myVar2 = (string)table.Rows[0]["Col3"];
} 

你可能想看看像dapper这样的MicroORM