Asp.net SqlDataReader转成Datatable

所属栏目:Asp.net 编程 | 发布日期:2013年04月05日 | 点击:517 次
内容摘要:Asp.net 数据存储,呈现方式有多种,如DataSet,DataTable,DataView,DataReader,IList等等,做得多了,常会需要将数据存储类型相互转换,这边介绍DataReader转DataTable的方法。
  1. /// <summary>
  2. /// SqlDataReader转成DataTable实现方法
  3. /// </summary>
  4. /// <param name="strSql"></param>
  5. /// <returns></returns>
  6. protected DataTable DataReaderToDataTable(string strSql)
  7. {
  8. string connstr = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
  9. SqlConnection sqlConn = new SqlConnection(connstr);
  10. SqlCommand sqlComm = new SqlCommand(strSql, sqlConn);
  11. SqlDataReader dataReader = null;
  12. DataTable dtReturn = null;
  13. object[] value = null;
  14. try
  15. {
  16. sqlComm.Connection.Open();
  17. dataReader = sqlComm.ExecuteReader();
  18. if (dataReader.HasRows)
  19. {
  20. dtReturn = CreateTableBySchemaTable(dataReader.GetSchemaTable());
  21. value = new object[dataReader.FieldCount];
  22. while (dataReader.Read())
  23. {
  24. dataReader.GetValues(value);
  25. dtReturn.LoadDataRow(value, true);
  26. }
  27. value = null;
  28. }
  29. }
  30. catch (Exception err)
  31. {}
  32. finally
  33. {
  34. dataReader.Close();
  35. sqlComm.Connection.Close();
  36. sqlComm.Dispose();
  37. }
  38. return dtReturn;
  39. }
  40. /// <summary>
       

    /// 本方法创建表各个列的名

    /// </summary>

    /// <param name="pSchemaTable">是一个表的结构表</param>

    /// <returns></returns>

  41. protected DataTable CreateTableBySchemaTable(DataTable pSchemaTable)
  42. {
  43. DataTable dtReturn = new DataTable();
  44. DataColumn dc = null;
  45. DataRow dr = null;
  46. for (int i = 0; i < pSchemaTable.Rows.Count; i++)
  47. {
  48. dr = pSchemaTable.Rows[i];
  49. dc = new DataColumn(dr["ColumnName"].ToString(), dr["DataType"] as Type);
  50. dtReturn.Columns.Add(dc);
  51. }
  52. dr = null;
  53. dc = null;
  54. return dtReturn;
  55. }
    /// <summary>
/// SqlDataReader转成DataTable实现方法
/// </summary>
/// <param name="strSql"></param>
/// <returns></returns>
protected DataTable DataReaderToDataTable(string strSql)
{
string connstr = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
SqlConnection sqlConn = new SqlConnection(connstr);
SqlCommand sqlComm = new SqlCommand(strSql, sqlConn);
SqlDataReader dataReader = null;
DataTable dtReturn = null;
object[] value = null;
try
{
sqlComm.Connection.Open();
dataReader = sqlComm.ExecuteReader();
if (dataReader.HasRows)
{
dtReturn = CreateTableBySchemaTable(dataReader.GetSchemaTable());
value = new object[dataReader.FieldCount];
while (dataReader.Read())
{
dataReader.GetValues(value);
dtReturn.LoadDataRow(value, true);
}
value = null;
} }
catch (Exception err)
{}
finally
{
dataReader.Close();
sqlComm.Connection.Close();
sqlComm.Dispose();
}
return dtReturn;
}

    /// <summary>
   
/// 本方法创建表各个列的名
   
/// </summary>
   
/// <param name="pSchemaTable">是一个表的结构表</param>
   
/// <returns></returns>
protected DataTable CreateTableBySchemaTable(DataTable pSchemaTable)
{
DataTable dtReturn = new DataTable();
DataColumn dc = null;
DataRow dr = null;
for (int i = 0; i < pSchemaTable.Rows.Count; i++)
{
dr = pSchemaTable.Rows[i];
dc = new DataColumn(dr["ColumnName"].ToString(), dr["DataType"] as Type);
dtReturn.Columns.Add(dc);
}
dr = null;
dc = null;
return dtReturn;
}

方法来自互联网,忘记从哪来的,在此注明。

作者:www.btnan.com,来源于:http://www.btnan.com,尊重作者,转载请注明。

 

Asp.net SqlDataReader转成Datatable的更多相关文章

  1. Asp.net GridView转换成DataTable

    GridView绑定DataTable后,如何获取GridView绑定后显示的值,在项目需求需要的背景下,搜索了获取单元格显示文本的方法,然后写了一个静态方法,经过在项目中的使用,bug的修复,较为稳 ...

  2. SqlDataReader 结果集 转成 DataTable

    /// <summary> /// SqlDataReader 转成 DataTable /// 源需要是结果集 /// </summary> /// <param na ...

  3. 利用反射将Datatable、SqlDataReader转换成List模型

    1. DataTable转IList public class DataTableToList<T>whereT :new() { ///<summary> ///利用反射将D ...

  4. .Net中List<T> 泛型转成DataTable、DataSet

    在开发过程过程中有时候需要将List<T>泛型转换成DataTable.DataSet,可以利用反射机制将DataTable的字段与自定义类型的公开属性互相赋值. 1.List<T& ...

  5. SQLBulkCopy使用实例--读取Excel写入数据库/将 Excel 文件转成 DataTable

    MS SQL Server 提供一个称为 bcp 的流行的命令提示符实用工具,用于将数据从一个表移动到另一个表(表可以在不同服务器上). SqlBulkCopy 类允许编写提供类似功能的托管代码解决方 ...

  6. 带复杂表头合并单元格的HtmlTable转换成DataTable并导出Excel

    步骤: 一.前台JS取HtmlTable数据,根据设定的分隔符把数据拼接起来 <!--导出Excel--> <script type="text/javascript&qu ...

  7. C#_List转换成DataTable

    /// <summary> /// 讲list集合转换成datatable /// </summary> /// <param name="list" ...

  8. 将List转换成DataTable

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...

  9. list转换成DataTable

    list转换成DataTable类如下: public static DataTable ToDataTable<T>(this IList<T> datas) { DataT ...

随机推荐

  1. Mongo客户端

    http://www.linuxidc.com/Linux/2012-07/64233.htm http://www.oschina.net/p/rockmongo http://www.cnblog ...

  2. TCP的那些事(转载)

    (转载本站文章请注明作者和出处 酷 壳 – CoolShell.cn ,请勿用于任何商业用途) TCP是一个巨复杂的协议,因为他要解决很多问题,而这些问题又带出了很多子问题和阴暗面.所以学习TCP本身 ...

  3. HDOJ-1041 Computer Transformation(找规律+大数运算)

    http://acm.hdu.edu.cn/showproblem.php?pid=1041 有一个初始只有一个1的串 每次都按①0 -> 10;②1 -> 01;这两条规则进行替换 形如 ...

  4. CentOS6.5与XP双系统安装

    因为工作的须要,须要安装一个XP系统和一个CentOS系统.依照在网上找到的一些方法尝试了下,结果都不是非常理想.最后,经过尝试和寻找,找到了一个比較方便的方法. 一.分区 本人的电脑硬盘是500G, ...

  5. optimizer for eclipse--Eclipse优化,让你的Eclipse快来飞!

    官方网站:http://zeroturnaround.com/free/optimizer-for-eclipse/ infoq网址:http://www.infoq.com/cn/news/2015 ...

  6. 【单点更新,区间查询,线段树】【HDU1166】【敌兵布阵】

    线段树要捡回来学了 才知道以前抄的模板就是杭电传奇学长写的,写起来更有激情了: 一点注意: 单点更新完后记得pushup(),向上更新信息 以下是对线段树的理解 线段树的节点代表一段线段,节点编号没有 ...

  7. C#运用实例.读取csv里面的词条,对每一个词条抓取百度百科相关资料,然后存取到数据库

    第一步:首先需要将csv先装换成datatable,这样我们就容易进行对datatable进行遍历: /// 将CSV文件的数据读取到DataTable中 /// CSV文件路径 /// 返回读取了C ...

  8. node.js url模块

    URL url.parse(urlStr[, parseQueryString][, slashesDenoteHost]) url.format(urlObj) url.resolve(from, ...

  9. git clone 命令报错 +diffie-hellman-group1-sha1

    解决方法: 在.ssh目录下新建文件config , 添加 Host * KexAlgorithms +diffie-hellman-group1-sha1 到文件config,即可.

  10. jvm如何知道那些对象需要回收

    1 首先的问题是:jvm如何知道那些对象需要回收 ? 目前有两种算法 引用计数法 每个对象上都有一个引用计数,对象每被引用一次,引用计数器就+1,对象引用被释放,引用计数器-1,直到对象的引用计数为0 ...