从数据库中读取数据:

使用DataReader对象从数据库中读取数据

首先需要添加几个命名空间

 //需要添加的命名空间
using System.Configuration;
using System.Data;
using System.Data.SqlClient;

配置文件如下

 <configuration>
<connectionStrings>
<add name="NorthwindConnectionString" connectionString="Data Source=TANGPRO-PC;Initial Catalog=Northwind;Integrated Security=True"
providerName="System.Data.SqlClient" />
</connectionStrings>
</configuration>

具体实现代码

         //从配置文件中读取数据库连接信息
string conStr = ConfigurationManager.ConnectionStrings["NorthwindConnectionString"].ConnectionString;
SqlConnection conn = new SqlConnection(conStr);//使用SqlConnection对象与数据库相连接 //Command对象使用Connection对象执行SQL查询,它返回的结果通常存储在 DataSet或DataReader中
SqlCommand myCommand = new SqlCommand();
myCommand.CommandText = "SELECT TOP 3 * FROM CUSTOMERS"; //需要执行的SQL语句
myCommand.CommandType = CommandType.Text; //CommandType.Text 表示 SQL 语句是内部文本
myCommand.Connection = conn; //SqlCommand对象的连接对象 //打开连接
myCommand.Connection.Open(); //此处存放在 DataReader中
SqlDataReader myReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection); //将返回的数据绑定到 GridView控件中
GridView1.DataSource = myReader;
GridView1.DataBind(); //读取完毕后销毁连接
myCommand.Dispose();
conn.Dispose();

结果:

使用数据适配器

  • SqlDataAdaper是一个特殊的类,其作用是在断开连接的DataTable对象和物理数据源之间搭起桥梁
  • 其提供双向的传输机制,它可以在数据源上执行SELECT语句,将结果传送到DataTable对象中,还可以执行标准的INSERT,UPDATE,DELETE语句,从DataTable对象中提取输入的数据
  • SqlDataAdaper类提供了一个Fill()方法,调用Flii()方法将执行SelectCommand属性中提供的命令,获取结果集,并把它复制到DataTable对象中

实现代码:

    protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
//从配置文件中读取数据库连接信息
string conStr = ConfigurationManager.ConnectionStrings["NorthwindConnectionString"].ConnectionString;
SqlConnection conn = new SqlConnection(conStr);//使用SqlConnection对象与数据库相连接 SqlCommand cmd = new SqlCommand();
cmd.CommandType = CommandType.Text;
cmd.Connection = conn;
cmd.CommandText = "SELECT TOP 5 * FROM CUSTOMERS"; DataTable myTable = new DataTable(); SqlDataAdapter myAdapter = new SqlDataAdapter(); //使用前面创建的 SqlCommand 对象填充 DataAdapter对象的SelectCommand属性
myAdapter.SelectCommand = cmd; //调用Flii()方法将执行SelectCommand属性中提供的命令,获取结果集,并把它复制到DataTable对象中
myAdapter.Fill(myTable); //Fill()方法返回一个已填充的DataTable对象 GridView1.DataSource = myTable.DefaultView;
GridView1.DataBind(); myAdapter.Dispose();
cmd.Dispose();
conn.Dispose();
} }

结果

使用参数

        protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
string conStr = ConfigurationManager.ConnectionStrings["NorthwindConnectionString"].ConnectionString;
SqlConnection conn = new SqlConnection(conStr); SqlCommand myCommand = new SqlCommand();
myCommand.CommandType = CommandType.Text;
myCommand.Connection = conn;
myCommand.CommandText = "SELECT * FROM CUSTOMERS WHERE CITY = @CITY AND CONTACTNAME= @CONTACT"; //此处使用了参数@CITY @CONTACT //创建SqlParameter对象,使用参数有助于防止可能的 SQL 注入攻击
//一般只需要填写ParameterName 和 Value属性即可
SqlParameter cityPara = new SqlParameter();
cityPara.ParameterName = "@CITY"; //这个读写属性获取或设置参数的名称
cityPara.SqlDbType = SqlDbType.VarChar; //获取或设置参数值的SQL Server数据库类型
cityPara.Size = ; //这个读写属性获取或设置参数值的大小
cityPara.Value = "Berlin"; //参数对象提供的值,这个值在运行期间传送给命令中定义的参数 SqlParameter contactPara = new SqlParameter();
contactPara.ParameterName = "@CONTACT";
contactPara.SqlDbType = SqlDbType.VarChar;
contactPara.Size = ;
contactPara.Value = "Maria Anders"; //向SqlCommand对象中加入参数
myCommand.Parameters.Add(cityPara);
myCommand.Parameters.Add(contactPara); myCommand.Connection.Open(); SqlDataReader myReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection); GridView1.DataSource = myReader;
GridView1.DataBind(); myCommand.Dispose();
conn.Dispose();
}
}

第二种加入参数的方法(更简便)

            myCommand.CommandText = "SELECT * FROM CUSTOMERS WHERE CITY = @CITY AND CONTACTNAME= @CONTACT"; //此处使用了参数@CITY @CONTACT

                 myCommand.Parameters.Add(new SqlParameter("CITY", "Berlin")); //期中CITY对应 SQL语句中的 @CITY   ,Berlin是其需要输入的值
myCommand.Parameters.Add(new SqlParameter("CONTACT", "Maria Anders"));

结果:

Ado.Net基础拾遗一:读取数据的更多相关文章

  1. Ado.Net基础拾遗二:插入,更新,删除数据

    插入数据 public void InsertDataToSQL() { string conStr = ConfigurationManager.ConnectionStrings["No ...

  2. vtk基础编程(2)-读取数据文件中的坐标点

    原文地址: http://blog.csdn.net/chinamming/article/details/16860051 1. 案例说明 在实际计算中,常常需要大量的数据, 这个时候数据文件就必不 ...

  3. .NET基础拾遗(6)ADO.NET与数据库开发基础

    Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开发基 ...

  4. 在VC下采用ADO实现BLOB(Binary)数据的存储,读取,修改,删除。

    在VC下采用ADO实现BLOB(Binary)数据的存储,读取,修改,删除. 作者:邵盛松 2009-09-05 前言 1关于的BLOB(Binary)数据的存储和读取功能主要参考了MSDN上的一篇& ...

  5. .NET基础拾遗(8)ADO.NET与数据库开发基础

    1.1 ADO.NET支持哪几种数据源? ① System.Data.SqlClient .NET程序员最常用的了.通过OLEDB或者ODBC都可以访问,但是SqlClient下的组件直接针对MSSQ ...

  6. 第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

    第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform ...

  7. XML基础以及用DOM4j读取数据

    都知道,HTML被设计用来显示数据,XML被设计用来保存.数据传输.而我们平时经经常使用的无非是保存数据.读取数据.所以这里主要介绍XML相关基础内容.以及用DOM4j来存取XML的数据. 以下简单介 ...

  8. 归纳从文件中读取数据的六种方法-JAVA IO基础总结第2篇

    在上一篇文章中,我为大家介绍了<5种创建文件并写入文件数据的方法>,本节我们为大家来介绍6种从文件中读取数据的方法. 另外为了方便大家理解,我为这一篇文章录制了对应的视频:总结java从文 ...

  9. Java基础知识强化之IO流笔记29:BufferedOutputStream / BufferedInputStream(字节缓冲流)之BufferedInputStream读取数据

    1. BufferedInputStream读取数据 BufferedInputStream构造方法,如下: 构造方法摘要 BufferedInputStream(InputStream in)    ...

随机推荐

  1. pageContext对象的用法详述

    pageContext对象  这个对象代表页面上下文,该对象主要用于访问JSP之间的共享数据. pageContext是PageContext类的实例,使用pageContext可以访问page.re ...

  2. {CodeForces】788E New task && 汕头市队赛SRM06 D 五色战队

    D 五色战队 SRM 06 背景&&描述         游行寺家里人们的发色多种多样,有基佬紫.原谅绿.少女粉.高级黑.相簿白等.         日向彼方:吾令人观其气,气成五彩, ...

  3. poj 2312 Battle City(优先队列+bfs)

    题目链接:http://poj.org/problem?id=2312 题目大意:给出一个n*m的矩阵,其中Y是起点,T是终点,B和E可以走,S和R不可以走,要注意的是走B需要2分钟,走E需要一分钟. ...

  4. inno setup 5 添加快捷方式默认选中

    转载:https://www.cnblogs.com/x_wukong/p/5012412.html https://zhidao.baidu.com/question/312006120.html ...

  5. 【反演复习计划】【COGS2432】爱蜜莉雅的施法

    也是一个反演. 第一次手动推出一个简单的式子,激动.jpg 原题意思是求:$Ans=\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}\phi(gcd(i,j))$随 ...

  6. [ LDAP ] LDAP服务搭建及应用

    ldap 搭建及应用 node1: 192.168.118.14node2: 192.168.118.25 ldap server : 192.168.118.14 1. 安装LDAP服务器 [roo ...

  7. python tips:列表推导

    看一个代码: a=[1,2,3,4,5,6,7,8,9] b=[5 if (i >3) else 1 for i in a] print(b) 这就是列表推导. 列表推导一般用在通过一个list ...

  8. Deep Learning关于Vision的Reading List

    最近开始学习深度学习了,加油! 下文转载自:http://blog.sina.com.cn/s/blog_bda0d2f10101fpp4.html 主要是顺着Bengio的PAMI review的文 ...

  9. Python 进阶 之 @property

    @property是一个装饰器,由Python原生库所支持,无需import @property 的作用是将函数变成属性,一般作用于类内的成员函数. 先贴个代码来描述一下@poperty存在的意义: ...

  10. Python 进阶 之 yield

    .转载自:https://www.ibm.com/developerworks/cn/opensource/os-cn-python-yield/ Python yield 使用浅析: 您可能听说过, ...