原文链接:https://blog.csdn.net/zhang_hui_cs/article/details/7327395

using System.Data;

using System.Data.SqlClient;

//SqlDataAdapter的MSDN网站:http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqldataadapter.aspx

//DataTable的MSDN网站:http://msdn.microsoft.com/en-us/library/system.data.datatable.aspx

//DataSet的MSDN网站: http://msdn.microsoft.com/en-us/library/system.data.dataset.aspx

//DataSets, DataTables, and DataViews (ADO.NET): http://msdn.microsoft.com/en-us/library/ss7fbaez.aspx

namespace Chapter13

{

class FilterSort

{

static void Main(string[] args)

{

// connection string

string connString = @"

server = .;

integrated security = true;

database = northwind

";

// query 1

string sql1 = @" select      *    from    customers   ; ";

// query 2

string sql2 = @"     select    *   from   products   where     unitprice < 10    ";

// combine queries

string sql = sql1 + sql2;

// create connection

SqlConnection conn = null;

try

{

conn = new SqlConnection(connString);

// create data adapter

SqlDataAdapter da = new SqlDataAdapter(sql, conn);

// create and fill data set

DataSet ds = new DataSet();

/*

* 如果SqlDataAdapter对应的sql语句返回多个数据集,

* 则SqlDataAdapter对应的DataTable名

* 会被依次命名为"Table", "Table1","Table2"……

* 如下调用得到的将会把"Table"对应着"Customers",

* "Table1"对应着"Products"

*/

da.TableMappings.Add("Table", "Customers");

da.TableMappings.Add("Table1", "Products");

da.Fill(ds);

// get the data tables collection

DataTableCollection dtc = ds.Tables;

//输出DataTableCollection中所有表的表名。

System.Console.WriteLine("DataTable in the DataTableCollection: ");

foreach (DataTable dt in dtc)

{

System.Console.WriteLine("\t{0}", dt.ToString());

}

// display data from first data table

//

// display output header

System.Console.WriteLine("Results from Customers table:");

System.Console.WriteLine(

"CompanyName".PadRight(20) +

"ContactName".PadLeft(23) + "\n");

// set display filter

string fl = "country = 'Germany'";

// set sort

string srt = "companyname asc";

foreach (DataRow row in dtc["Customers"].Select(fl, srt))   //  dtc["Customers"] 是DataTable , 看为内存的一张数据库表 , 按照条件+排序查询

{

System.Console.WriteLine(

"{0}\t{1}",

row["CompanyName"].ToString().PadRight(25),

row["ContactName"]);

}

// display data from second data table

//

// display output header

System.Console.WriteLine("\n----------------------------");

System.Console.WriteLine("Results from Products table:");

System.Console.WriteLine(

"ProductName".PadRight(20) +

"UnitPrice".PadLeft(21) + "\n");

//下句中dtc["Products"]中还可以按照表索引值访问,等价于dtc[1]

foreach (DataRow row in dtc["Products"].Rows)

{

System.Console.WriteLine("{0}\t{1}",

row["productname"].ToString().PadRight(25),

row["unitprice"]);

}

}

catch (System.Exception e)

{

System.Console.WriteLine("Error: " + e);

}

finally

{

// close connection

conn.Close();

}

}

}

}

SqlDataAdapter、DataSet、DataTable使用的更多相关文章

  1. sqldataAdapter/dataset/datatable的使用

    public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void Form1_Loa ...

  2. C#使用DataSet Datatable更新数据库的三种实现方法

    本文以实例形式讲述了使用DataSet Datatable更新数据库的三种实现方法,包括CommandBuilder 方法.DataAdapter 更新数据源以及使用sql语句更新.分享给大家供大家参 ...

  3. ADO.NET基础知识学习(SQLCOnnection&SQLCommand&SQLDataReader&SQLDataAdapter&DataSet)

    通过ADO.NET技术,我们可以高效的完成客户端同数据库之间的数据访问操作,便于我们在客户端程序简便高效的访问以及获取数据库中的有用数据,同时也可以对数据库中的数据进行更新,即可以完成客户端与数据库之 ...

  4. 手写DataSet,DataTable

    一:DataSet DataSet ds = new DataSet();//创建DataSet DataTable dt = new DataTable();//创建一个DataTalbe dt.C ...

  5. DataSet DataTable操作

    DataSet ds = new DataSet();            DataTable dt = new DataTable("OrderList");          ...

  6. [Json] C#ConvertJson|List转成Json|对象|集合|DataSet|DataTable|DataReader转成Json (转载)

    点击下载 ConvertJson.rar 本类实现了 C#ConvertJson|List转成Json|对象|集合|DataSet|DataTable|DataReader转成Json|等功能大家先预 ...

  7. DataSet,DataTable,DataColumn,DataRow的常用操作

    DataSet 这个玩意没什么好讲的,当ado.net查询出有多张表集合的数据返回时,这个时候就会使用到DataSet. DataTable //表之间直接赋值 dt2=dt1; 两者指向同一内存空间 ...

  8. 【C#-批量插入数据到数据库】DataTable数据批量插入数据的库三种方法:SqlCommand.EcecuteNonQurery(),SqlDataAdapter.Update(DataTable) ,SqlBulkCopy.WriteToServer(Datatable)

    第一种方法:使用SqlCommand.EcecuteNonQurery()  效率最慢 第二种方法:使用SqlDataAdapter.Update(DataTable)   效率次之 第三种方法:使用 ...

  9. DataSet,DataTable排序(转载)

    DataSet,DataTable排序   关于对已经绑定的DataSet的排序的问题: DataSet ds=new DataSet();DataView dv=new DataView();dv. ...

  10. 使用DataSet Datatable 更新数据库的三种方式

    1:自动生成命令的条件 CommandBuilder 方法a)动态指定 SelectCommand 属性b)利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteC ...

随机推荐

  1. shell-删除指定时间前的文件

    需要配合find和rm两个命令完成 显示20分钟前的文件: find /home/prestat/bills/test -type f -mmin +20 -exec ls -l {} \; 删除20 ...

  2. 假期学习【四】RDD编程实验一

    1.今天把Spark编程第三个实验的Scala独立程序编程写完了.使用 sbt 打包 Scala 程序,然后提交到Spark运行. 2.完成了实验四的第一项 (1)该系总共有多少学生:   map(t ...

  3. SKlearn | 学习总结

    1 简介 scikit-learn,又写作sklearn,是一个开源的基于python语言的机器学习工具包.它通过NumPy, SciPy和Matplotlib等python数值计算的库实现高效的算法 ...

  4. Java并发,synchronized锁住的内容

    synchronized用在方法上锁住的是什么? 锁住的是当前对象的当前方法,会使得其他线程访问该对象的synchronized方法或者代码块阻塞,但并不会阻塞非synchronized方法. 脏读 ...

  5. arm学习笔记

    学习ARM也有一定时间了,想想还是记点东西,要不以后就忘了.这是我的第一片,简简单单.但比较基础.1. ARM中一些常见英文缩写解释MSB:最高有效位:LSB:最低有效位:AHB:先进的高性能总线:V ...

  6. pycharm运行RF脚本时的环境搭建与配置

    1.安装pycharm:2.file->setting,下载插件intellibot,重启pycharm:3.配置识别RF类型文件,filefile->editor->file ty ...

  7. bootstrap资料索引

    中文手册  :  http://w3c.3306.biz/bootstrap_forms/show-25-64-1.html

  8. c# 嵌入资源并读取

    原文:c# 嵌入资源并读取 1. 右键点击项目,选择资源,然后选择资源的类型,插入资源. 2. 这时候在项目的目录树上会出现一个Resource的文件夹,找到嵌入的资源文件,右击属性,在 Build ...

  9. 创建JDBC六个步骤

    JDBC库中所包含的API通常与数据库使用于: 连接到数据库 创建SQL或MySQL语句 在数据库中执行SQL或MySQL查询 查看和修改数据库中的数据记录 创建JDBC应用程序 建立一个JDBC应用 ...

  10. C语言-宏定义与使用分析

    1.C语言中的宏定义 #define是预处理器处理的单元实体之— #define定义的宏可以出现在程序的任意位置 #define定义之后的代码都可以使用这个宏 2.定义宏常量 #define定义的宏常 ...