0

我在 Azure SQL Server 上跨多个数据库运行查询时遇到问题。这是我在执行后从查询中返回 DataTable 的函数。该函数将数据库名称作为字符串并将其与要执行的查询一起插入到连接字符串中。

该函数在我运行一次时运行良好,按预期返回填充了返回行的 DataTable,但是当我使用“foreach”语句调用该函数(遍历数据库名称列表)时,出现超时错误或登录失败错误。

对此的任何帮助将不胜感激。

  public static DataTable runQuery(String db, String query)
  {

    using (SqlConnection con = new SqlConnection("Data Source=server.database.windows.net;Initial Catalog=" + db + ";User ID=user@server;Password=password"))
    {

        con.Open();

        using (DataTable dt = new DataTable())
        {

            try
            {

                SqlCommand cmd = new SqlCommand(query, con);
                SqlDataAdapter da = new SqlDataAdapter(cmd);

                da.Fill(dt);

                cmd.Dispose();
                da.Dispose();

            }

            catch (SqlException ex)
            {
                MessageBox.Show(ex.Message);
            }

            return dt;
        }

    }
}
4

2 回答 2

0

我认为您应该尝试System.Threading.Thread.Sleep在 foreach 块中添加。

于 2013-02-27T11:19:43.503 回答
0

添加cmd.CommandTimeout = 0

try
            {

                SqlCommand cmd = new SqlCommand(query, con);
                cmd.CommandTimeout = 0;
                SqlDataAdapter da = new SqlDataAdapter(cmd);

                da.Fill(dtt);

                cmd.Dispose();
                da.Dispose();

            }
于 2013-02-27T11:45:18.133 回答