-1

我的网站(远程)上有一个 sql server 表。该表被调用table1并包含一堆字段。我的目标是将 的所有字段读table1入一个名为results.

这是我的尝试:

 private static void ShowFields()
        {
            using (SqlConnection connection = new SqlConnection(connectionstring))
            {
                connection.Open();

                SqlCommand command = new SqlCommand("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='table1'", connection);

                string[] results = command.BeginExecuteNonQuery().ToArray();

                connection.Close(); 

                foreach (var v in results)
                {
                    Console.WriteLine(v); 
                }
            }
        }
4

3 回答 3

0

你会想要探索

SqlCommand.ExecuteReader

或用结果填充数据集。

http://msdn.microsoft.com/en-us/library/bh8kx08z%28v=vs.71%29.aspx

BeginExecuteNonQuery 是异步的,我会继续这个,直到你掌握了基础知识。

于 2013-05-18T12:53:24.947 回答
0

您需要使用Sqlcoomand.Executereader()而不是:

 private static void ShowFields()
 {
     using (SqlConnection connection = new SqlConnection(connectionstring))
     {
         connection.Open();

         SqlCommand command = new SqlCommand("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='table1'", connection);
         SqlDataReader reader = command.ExecuteReader();

         connection.Close();

         int colCount = reader.FieldCount;

         while (reader.Read())
         {
             for (int i = 0; i < colCount; i++)
             {
                 Console.WriteLine(reader.GetString(i));
             }
         }
     }
 }
于 2013-05-18T13:50:43.150 回答
0

这是另一种方式:

 System.Data.SqlClient.SqlCommand c = new System.Data.SqlClient.SqlCommand();
 System.Data.DataTable T = new System.Data.DataTable();
 System.Data.SqlClient.SqlDataAdapter DA = new System.Data.SqlClient.SqlDataAdapter(c);
 c.commandtext = "select ..";
 DA.SelectCommand = c;
 c.Connection = new System.Data.SqlClient.SqlConnection(yourConnectionString);
 c.Connection.Open();
 DA.Fill(T);
        // close connection in finally block or use the using structure

然后检查T。

于 2013-05-18T13:59:19.807 回答