转自:http://www.cnblogs.com/csdm/archive/2010/02/02/1661808.html

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Dataset.aspx.cs" Inherits="Dataset" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>遍历Dataset并输出数据</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    
    </div>
    </form>
</body>
</html>

CS:

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Data.SqlClient;

public partial class Dataset : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {

//先来建立数据库
        DataSet Forum = new DataSet("Forum");

//再来建立两个数据表
        DataTable tbClass = new DataTable("tbClass");
        DataTable tbBoard = new DataTable("tbBoard");

//把两个数据表加入数据库
        Forum.Tables.Add(tbClass);
        Forum.Tables.Add(tbBoard);

//建立tbClass两列
        DataColumn ClassID = new DataColumn("ClassID", typeof(System.String));
        DataColumn ClassName = new DataColumn("ClassName", typeof(System.String));

//设定ClassID列不允许为空
        ClassID.AllowDBNull = false;

//把列加入tbClass表
        tbClass.Columns.Add(ClassID);
        tbClass.Columns.Add(ClassName);

//设定tdClass表的主键
        tbClass.PrimaryKey = new DataColumn[] { ClassID };

//建立tbBoard的三列
          DataColumn BoardID = new DataColumn("BoardID", typeof(System.String));
          DataColumn BoardName = new DataColumn("BoardName", typeof(System.String));
          DataColumn BoardClassID = new DataColumn("BoardClassID", typeof(System.String));

//设定BoardID列不允许为空
          BoardID.AllowDBNull = false;

//把列加入tbBoard表
          tbBoard.Columns.Add(BoardID);
          tbBoard.Columns.Add(BoardName);
          tbBoard.Columns.Add(BoardClassID);

//设定tbBoard表的主键
          tbBoard.PrimaryKey = new DataColumn[] { BoardID };

// 为两个表各加入5条记录
          for (int i = 1; i <= 5; i++)
          {
              //实例化tbClass表的行
              DataRow tbClassRow = tbClass.NewRow();
              //为行中每一列赋值
              tbClassRow["ClassID"] = Guid.NewGuid();
              tbClassRow["ClassName"] = string.Format("分类{0}", 1);

//把行加入tbClass表
              tbClass.Rows.Add(tbClassRow);
              //实例化tbBoard表的行
              DataRow tbBoardRow = tbBoard.NewRow();

//为行中每一列赋值
              tbBoardRow["BoardID"] = Guid.NewGuid();
              tbBoardRow["BoardName"] = string.Format("版块{0}", i);
              tbBoardRow["BoardclassID"] = tbClassRow["ClassID"];
              //把行加入tbBoard表

tbBoard.Rows.Add(tbBoardRow);

}

//DataRow tbClassRow = tbClass.NewRow();
          //for (int i = 1; i <= 5; i++)
          //{
          //    tbClassRow["ClassID"] = Guid.NewGuid();
          //    tbClassRow["ClassName"] = string.Format("分类{0}", i);
          //    tbClass.Rows.Add(tbClassRow);
          //}

//构建输出字符串
          System.Text.StringBuilder htmlStr = new System.Text.StringBuilder();
          //遍历Forum中的所有表(使用foreach)遍历
          foreach (DataTable dt in Forum.Tables)
          {
              //表开始
              htmlStr.Append("<table border='1' cellspacing='0' cellPadding='5' style='font-size:9pt;font:宋体'>");

//表头开始
              htmlStr.Append("<tr style='backgound-color:#F0F0F0'>");
              //遍历表中所有列(使用for遍历)
              for (int i = 0; i < dt.Columns.Count; i++)
              {
                  htmlStr.Append(string.Format("<td><strong>{0}</strong></td>", dt.Columns[i].ColumnName));
              }

//表头结束
              htmlStr.Append("</tr>");

//遍历表中所有行
              for (int i = 0; i < dt.Rows.Count; i++)
              {
                  //数据行开始
                  htmlStr.Append("<tr>");
                  //遍历行中列
                  for (int j = 0; j < dt.Columns.Count; j++)
                  {
                      if (!dt.Rows[i].IsNull(j))
                          htmlStr.Append(string.Format("<td>{0}</td>", dt.Rows[i][j]));
                  }
                  //数据行结束
                  htmlStr.Append("</tr>");
              }
              //表结束
              htmlStr.Append("</table><br>");
          }
          Response.Write(htmlStr);

}
}

遍历Dataset并输出数据实例的更多相关文章

  1. C# 手动编写 DataSet,DataTable 及遍历DataSet中的数据

    一.手动编写DataSet:    有时候不想从数据库导出 DataSet,或者有其他的需要,要将数据库里的DataSet包装成另一个样子,这个时候,了解DataSet的内部结构就非常必要.DataS ...

  2. Java学习笔记:基本输入、输出数据操作实例分析

    Java学习笔记:基本输入.输出数据操作.分享给大家供大家参考,具体如下: 相关内容: 输出数据: print println printf 输入数据: Scanner 输出数据: JAVA中在屏幕中 ...

  3. 遍历DataSet

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

  4. python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例

    python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...

  5. [C#] 常用工具类——直接在浏览器输出数据

    /// <summary> /// <para> </para> /// 常用工具类——直接在浏览器输出数据 /// <para> ---------- ...

  6. 你好,C++(5)如何输出数据到屏幕、从屏幕输入数据与读写文件?

    2.2  基本输入/输出流 听过HelloWorld.exe的自我介绍之后,大家已经知道了一个C++程序的任务就是描述数据和处理数据.这两大任务的对象都是数据,可现在的问题是,数据不可能无中生有地产生 ...

  7. Ajax应用-Ajax传输JSON数据实例

    ———————————————————— <script type="text/javascript">            var client;          ...

  8. C#遍历DataSet与DataSet元素实现代码

    C#中的Dataset就像一个数据库,有多个表(Table),一般只有一个表,然后每个表中有行(DataRow)和列(DataColumn),DataRow[DataColumn]可以得到某行某列数据 ...

  9. php、mysql查询当天,查询本周,查询本月的数据实例(字段是时间戳)

    php.mysql查询当天,查询本周,查询本月的数据实例(字段是时间戳) //其中 video 是表名: //createtime 是字段: // //数据库time字段为时间戳 // //查询当天: ...

随机推荐

  1. java Email发送及中文乱码处理。

    public class mail { private String pop3Server=""; private String smtpServer=""; ...

  2. iTerm 使用expect实现自动远程登录,登录跳板机

    #!/usr/bin/expect set timeout 10 spawn ssh -p [lindex $argv 0] [lindex $argv 1]@[lindex $argv 2] exp ...

  3. STL之优先队列

    STL 中优先队列的使用方法(priority_queu) 基本操作: empty() 如果队列为空返回真 pop() 删除对顶元素 push() 加入一个元素 size() 返回优先队列中拥有的元素 ...

  4. HBuilder手机Iphone运行提示“未受信用的企业级开发者”

    HBuilder手机Iphone运行提示“未受信用的企业级开发者” 解决方法:设置-----通用------设备管理-----点击Digtial Heaven....---信任"Digtia ...

  5. 通过shell脚本实现代码自动化部署

    通过shell脚本实现代码自动化部署 一.传统部署方式及优缺点 1.传统部署方式 (1)纯手工scp (2)纯手工登录git pull.svn update (3)纯手工xftp往上拉 (4)开发给打 ...

  6. linux下用户以及用户组管理

    /etc/passwd ‘/etc/passwd’ 由 ‘:’ 分割成7个字段,每个字段的具体含义是: 1)用户名.用户名字符可以是大小写字母.数字.减号(不能出现在首位).点以及下划线,其他字符不合 ...

  7. js在php 中出现 unterminated string literal 解决方法

    出现这个问题就是空格造成的(可清空格符,换行符等) 示例代码如下: php 下报错 <?php echo "<a href=javascript:if(window.confir ...

  8. Dataset

    1,if(ds == null) 这是判断内存中的数据集是否为空,说明DATASET为空,行和列都不存在!! 2,if(ds.Tables[0].Count == 0) 这应该是在内存中存在一个DAT ...

  9. PHP实现斐波那契数列非递归方法

    斐波那契数列,又称黄金分割数列,指的是这样一个数列:0.1.1.2.3.5.8.13.21.……在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n ...

  10. thinkphp给图片打水印不清晰

    项目中打印条形码的函数,从thinkphp自带的water函数修改而来的. 贴上代码: /** * water2 * 改写thinkphp的water函数更强健的函数,增加了写入位置参数 去掉了alp ...