目标:使用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语句的范围。什么是正确的方法?
答案 0 :(得分:3)
您的语句将返回多个结果集,如果您使用的是DataReader,那么您将获得多个结果。使用DataReader.NextResult
方法获取下一个结果集并相应地显示数据。
如果您不关心DataReader
,那么您可以使用DataSet
并使用DataAdapater
在DataSet内的多个DataTables
中填写结果。