如何使用多个select语句填充结构

时间:2013-09-23 20:16:47

标签: c# sql structure

目标:使用C#和SqlServer2005使用多个select语句填充结构

问题:目前我可以使用一个select语句填充结构,但由于这个特定select语句的性质,要生成正确的结果,查询需要分解,因此我有使用多个选择来填充一个结构。这是可能的还是我以错误的方式去做。以下是我正在使用的代码

public static bool GetColumns()
{
    String sql = "";

    try
    {
       conn.Open();

       sql = @"SELECT
                   database.dbo.table1.column1
               FROM
                   database.dbo.table1;

              SELECT
                   database.dbo.table2.column2
              FROM
                   database.dbo.table2;

              SELECT
                   database.dbo.table3.column3
              FROM    
                  database.dbo.table3 ;" ;

        SqlCommand cmd = new SqlCommand(sql, conn);

        SqlDataReader dr = cmd.ExecuteReader();

         MyStructure struct1 = new MyStructure();   

         while (dr.Read())
        {
           struct1.column1 = dr.GetValue(0);
           struct1.column2 = dr.GetValue(1);
           struct1.column3 = dr.GetValue(2);

          MyArrayList.Add(struct1);
        }

           dr.Close();

           conn.Close();

        return true;
 }

 catch (Exception ex)
 {
    if (conn.State == ConnectionState.Open)
        conn.Close();

    error.LogError(ex, "", "")
    return false
 }

上面的代码不起作用,因为我列出的值超出了每个单独的select语句的范围。什么是正确的方法?

1 个答案:

答案 0 :(得分:3)

您的语句将返回多个结果集,如果您使用的是DataReader,那么您将获得多个结果。使用DataReader.NextResult方法获取下一个结果集并相应地显示数据。

如果您不关心DataReader,那么您可以使用DataSet并使用DataAdapater在DataSet内的多个DataTables中填写结果。