贵宾哥Cyril 2023-03-07 12:09 采纳率: 25%
浏览 31
已结题

IDataReader如何快速转成DataTable?

IDataReader如何快速转成DataTable?
由于某些原因,不能使用IDbDataAdapter的Fill方法拿到DataSet,于是自己使用ExecuteReader拿到IDataReader并一行一行塞入DataTable,这样速度很慢。经过测试,拿到2W条数据,IDbDataAdapter.Fill()只需要12秒,而我自己转需要120秒+。网上看了下Fill的底层也是先执行ExecuteReader拿到IDataReader,再去转换成DataTable,但是我不明白它具体怎么做到这么快的。
需求:需要一个快速将IDataReader转成DataTable的方法,最好的情况是能跟Fill方法持平,或者直接能使用到Fill底层的转换方法。(网上的方法能搜到的都试过了,还是很慢)

  • 写回答

3条回答 默认 最新

  • 霸都小魔女 2023-03-07 12:20
    关注

    小魔女参考了bing和GPT部分内容调写:
    使用IDataReader转换DataTable的快速方法,可以使用Load方法,它可以将IDataReader的数据快速加载到DataTable中,而不用一行一行的去填充,这样可以提高转换的效率。

    下面是一个示例代码:

    DataTable dt = new DataTable();
    using (IDataReader reader = command.ExecuteReader())
    {
        dt.Load(reader);
    }
    

    Load方法可以将IDataReader中的数据快速加载到DataTable中,而不用一行一行的去填充,这样可以提高转换的效率,达到和IDbDataAdapter Fill()方法持平的效果。
    回答不易,记得采纳呀。

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月8日
  • 创建了问题 3月7日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。