zoukankan      html  css  js  c++  java
  • DataSet 类 (二) 读取数据

    使用方法

    1、创建DataSet对象

    DataSet ds = new DataSet();

    DataSet ds = new DataSet("DataSetName");

    2、用数据集填充DataSet

    最常用的是DataAdapter对象的Fill()方法给他填充数据

    (1)

    DataSet ds = new DataSet();

    SqlDataAdapter adapt = new SqlDataAdapter(sqlcmd,con)

    adapt.Fill(ds,"mytest");

    (2)

    DataSet ds=new DataSet();

    DataTable dt=new DataTable("newTable");

    ds.Tables.Add(dt);

    (3)

    DataSet ds=new DataSet();

    DataTable dt=ds.Tables.Add("newTable");

    3、访问DataSet中的表、行和列 值

    (1): 访问每个 DataTable

    按表名访问:ds.Tables["mytest"] //指定DataTable对象mytest(即访问DataSet中名为mytest的DataTable)

    按索引(索引基于0的)访问:ds.Tables[0] //指定DataSet中的第一个DataTable

    (2): 访问DataTable中的行

    ds.Tables["mytest"].Rows[n] //访问mytest表 的第n+1行(行的索引是从0开始的)

    ds.Tables[i].Rows[n] //访问DataSet中的第i+1个DataTable 的第n+1列(列的索引是从0开始的)

    (3): 访问DataTable中的某个元素

    ds.Tables["mytest"].Rows[n][m] //访问mytest表的第n+1行第m+1列的元素

    ds.Tables[i].Rows[n][m] //访问DataSet中的第i+1个DataTable 表的第n+1行第m+1列的元素

    ds.Tables["mytest"].Rows[n][name] //访问mytest表的第n+1行name列的元素

    ds.Tables[i].Rows[n][name] //访问DataSet中的第i+1个DataTable 表的第n+1行name列的元素

    (4): 取DataTable中的列名

    ds.Tables["mytest"].Columns[n] //取出mytest表的n+1列列名

    ds.Tables[i].Columns[n]

    4、实例

    using System;

    using System.Collections.Generic;

    using System.Text;

    using System.Data.SqlClient;

    using System.Data;

    namespace sqlconnection1

    {

    class Program

    {

    private void SQLConnectionF(string source, string select)

    {

    //创建连接

    SqlConnection con = new SqlConnection(source);

    SqlDataAdapter adapt = new SqlDataAdapter(select,con);

    try

    {

    con.Open();

    Console.WriteLine("connection is successful!");

    }

    catch (Exception e)

    {

    Console.WriteLine("connection error is :{0}", e.ToString());

    }

    //创建DataSet

    DataSet ds = new DataSet();

    //将数据添加到DataSet中

    adapt.Fill(ds,"mytest");

    //取出mytest表各列名

    Console.WriteLine("{0,-15} {1,-10} {2,-10}",ds.Tables["mytest"].Columns[0],

    ds.Tables["mytest"].Columns[1],ds.Tables["mytest"].Columns[2]);

    //输出mytest表中第六行

    DataRow row1 = ds.Tables["mytest"].Rows[5];

    Console.WriteLine("{0,-15} {1,-10} {2,-10}",row1[0],row1[1],row1[2]);

    //输出mytest表中第五行的第二列的值

    DataRow row2 = ds.Tables["mytest"].Rows[4];

    Console.WriteLine(" {0,-25} ", row2[1]);

    //下列两种方法等效都等同于row2[1](即第五行的第二列的值)

    Console.WriteLine(" {0,-25} ", ds.Tables["mytest"].Rows[4][1]);

    Console.WriteLine(" {0,-25} ", ds.Tables["mytest"].Rows[4]["number"]);

    //输出DataSet中的所有数据

    foreach (DataRow row in ds.Tables["mytest"].Rows)

    {

    Console.WriteLine("{0,-15} {1,-10} {2,-10} {3}",row["name"] ,

    row["number"] , row["low"] , row["high"]);

    //取第三列的值

    Console.WriteLine("{0,-15} ", row[3]);

    }

    Console.ReadLine();

    con.Close();

    }

    static void Main(string[] args)

    {

    string sou = "server=duanyf//SQLEXPRESS;" + "Initial Catalog=master;" + "UID = sa;" + "Password = dyf123";

    string sel = "SELECT name,number,low,high From dbo.spt_values";

    Program sqlcon = new Program();

    sqlcon.SQLConnectionF(sou, sel);

    }

    }

    }

  • 相关阅读:
    OSPF
    【今日CS 视觉论文速览】 24 Jan 2019
    【今日CS 视觉论文速览】Wed, 23 Jan 2019
    【今日CS 视觉论文速览】 21 Jan 2019
    【Processing学习笔记】安装与入门
    【今日CS 视觉论文速览】Part2, 18 Jan 2019
    【今日CS 视觉论文速览】Fri, 18 Jan 2019
    【今日CS 视觉论文速览】Thu, 17 Jan 2019
    【今日CS 视觉论文速览】Part2, 16 Jan 2019
    【今日CS 视觉论文速览】Wed, 16 Jan 2019
  • 原文地址:https://www.cnblogs.com/dyufei/p/2573960.html
Copyright © 2011-2022 走看看