> 文档中心 > [C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验

[C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验


[C# VSTO Word]使用DataSet的TableAdapter中GetData查询类返回结果遇到的坑和解决经验

  • 使用DataSet的TableAdapter中GetData开头的查询,结果会要求存储在一个【新的DataTable】中。

[C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验

  • 代码中其返回值会要求给一个【新的DataTable】
using (MyDataSet.NorthwindDatasetTableAdapters.内容来源TableAdapter 内容来源TableAdapter    = new MyDataSet.NorthwindDatasetTableAdapters.内容来源TableAdapter()){    MyDataSet.NorthwindDataset.内容来源DataTable 内容来源DataTable = 内容来源TableAdapter.GetDataBy_判断来源是否已有_返回GUID(  来源FilePath,  来源FileName  );    if (内容来源DataTable.Count > 0)    { GUID_Temp_内容来源LY = 内容来源DataTable[0].GUID.ToString(); //DataTable的记录索引默认从0开始    }    else    { GUID_Temp_内容来源LY = System.Guid.NewGuid().ToString();    }    内容来源DataTable.Dispose();}
  • 如果这个GetData方法中返回的【新的DataTable】结果表结构不是全字段的话。如下图所示。

[C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验

  • 运行时则会报错。
    [C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验
  • 哪怕加上键字段,可能远程数据库中的值设置的非NULL约束太多了。
    [C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验
  • 因此,如无必要,最好的解决方式就是,需要改成全部字段。亲测运行正常。
    [C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验
  • 通过给关键代码行打上断点,可以看到返回了想要的记录。虽然多了不少额外字段,但本着不求高级,但求好用的原则,至少运行通过了,目的实现了不是么?
    [C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验

结论:

使用DataSet的TableAdapter中GetData开头的查询,结果会要求存储在一个【新的DataTable】中。这个【新的DataTable】需要与原表的字段一致。

[C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验

[C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验 创作打卡挑战赛 [C# VSTO Word]使用DataSet的TableAdapter中GetData查询类,其返回结果遇到的坑和解决经验 赢取流量/现金/CSDN周边激励大奖