首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SqlDataAdapter问题

SqlDataAdapter问题
EN

Stack Overflow用户
提问于 2010-09-25 05:55:42
回答 2查看 336关注 0票数 1

有几个返回DataTable对象的查询需要执行。为了加快开发速度,我创建了一个私有方法,该方法应以查询字符串作为参数返回dataset。

方法如下:

代码语言:javascript
复制
private DataTable getDataTable(string query)
    {
        DataTable dt = new DataTable();
        SqlDataAdapter DA = new SqlDataAdapter(query, conn);
        try
        {
            iStatusIndicator.SetBusy(true);
            iStatusIndicator.SetStatus("executing query" + query);
            DA.Fill(dt);
        }
        catch (Exception ex)
        {
            ...
        }
        iStatusIndicator.SetBusy(false);
        iStatusIndicator.SetStatus("");
        return dt;
    }

该过程不会抛出异常,但DataTable dt始终为空。我尝试在sql命令提示符中直接运行查询字符串,但它按预期返回数据,因此我不知道问题出在哪里。

如果你们中的任何人解释了原因,提出了修复方法或通过接收查询字符串返回DataTables的更好方法,我将非常感谢。

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-09-25 06:01:50

代码语言:javascript
复制
private static DataSet SelectRows(DataSet dataset,
    string connectionString,string queryString) 
{
    using (SqlConnection connection = 
        new SqlConnection(connectionString))
    {
        SqlDataAdapter adapter = new SqlDataAdapter();
        adapter.SelectCommand = new SqlCommand(
            queryString, connection);
        adapter.Fill(dataset);
        return dataset;
    }
}
票数 0
EN

Stack Overflow用户

发布于 2010-09-25 07:10:42

你的catch块里有什么?有没有可能有什么东西可以返回或退出sub?这似乎是我能看到此函数返回NOthing (即.您的函数永远不会到达"return dt;“行

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3791298

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档