首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从dataset中的表返回列值

从dataset中的表返回列值
EN

Stack Overflow用户
提问于 2014-05-14 07:25:12
回答 3查看 83.7K关注 0票数 13

我有一个包含两个表的数据集,我希望从第二个表中获得第一列的值,并将其初始化为int变量。

该列的名称是CONTACT_ID。

我试过这样做。

代码语言:javascript
复制
  int Contract_id = Convert.ToInt32(dsDiscounts.Tables[1].Columns[0]);

但它显示出一个错误:

无法将“System.Data.DataColumn”类型的对象强制转换为“System.IConverable”类型。

有人能帮帮我吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-05-14 07:27:38

dsDiscounts.Tables[1].Columns[0]返回列定义( DataColumn实例定义的数据类型、标题等)。当然,将列定义转换为整数失败。

您需要的是来自某一行表的单元格值(假设为第一行)。您应该使用Rows集合来访问表行。通过索引获得所需的DataRow后,可以访问行按指数列名、列对象等中的单元格。例如,通过列名获取第一行的单元格值:

代码语言:javascript
复制
 dsDiscounts.Tables[1].Rows[0]["CONTACT_ID"]
票数 35
EN

Stack Overflow用户

发布于 2014-05-14 07:27:39

尝尝这个

代码语言:javascript
复制
int Contract_id = Convert.ToInt32(dsDiscounts.Tables[1].Rows[0]["CONTACT_ID"]);
票数 3
EN

Stack Overflow用户

发布于 2020-10-13 06:35:49

代码语言:javascript
复制
public static T SafeGet<T>(this System.Data.DataSet dataset, string tableindex, int RowCount, string Nameofcolumn)
{
    try
    {
        return dataset.Tables[tableindex].Rows[RowCount].IsNull(Nameofcolumn) == false ?
            (T)Convert.ChangeType(dataset.Tables[tableindex].Rows[RowCount][Nameofcolumn], typeof(T))
            : default(T);
    }
    catch (Exception ex)
    {
        throw ex;
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23648132

复制
相关文章

相似问题

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