• 网络学院
  • 新手学堂
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
从一个程序出发详细研究DataReader
广告位
  站点:
  • 首 页
  • 最新软件
  • 最新文章
  • 国内软件
  • 国外软件
  • 汉化软件
  • 源码下载
  • 字体下载
从一个程序出发详细研究DataReader
软件发布 从一个程序出发详细研究DataReader
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回首页 | 文章首页 | 认证考试 | 程序员 | 从一个程序出发详细研究DataReader

从一个程序出发详细研究DataReader

 

添加时间: 2007-4-9 2:09:25  作者: 程序员认证参考  阅读次数:41   来源: http://www.d9soft.com

 

 

       

  using System;
  using System.Data;
  using System.Data.SqlClient;
  using System.Data.OleDb;
  
  class SqlReader
  {
   const string connStr = "data source=bineon;user id=sa;password=87345587;initial catalog=contract";
   SqlConnection conn;
  
  
   public SqlReader()
   {
   conn = new SqlConnection(connStr);
   }
  
   //**************************************
   //*演示DataReader的两种取值方法
   //**************************************
   public void basicReader()
   {
   string sql="select * from friend";
   SqlCommand cmd;
   cmd = conn.CreateCommand();
   cmd.CommandText = sql;
   conn.Open();
   SqlDataReader reader = cmd.ExecuteReader();
   while(reader.Read())
   {
    Console.WriteLine("No:{0} Name:{1} PhoneNum:{2}, Address:{3}",reader.GetInt32(0).ToString(),reader.GetString(1),reader[2].ToString(),reader["Faddress"].ToString());
   }
   showSplit();
   reader.Close();
   conn.Close();
   }
  
   //**************************************
   //*演示带参数查询的操作,使用SqlCilent
   //**************************************
   public void hasParamReader()
   {
   SqlCommand cmd;
   cmd = conn.CreateCommand();
   string sql = "select Fname,Fphone,Faddress from friend where Fid > @Fid";
   cmd.CommandText = sql;
   SqlParameter param = new SqlParameter("@Fid",SqlDbType.Int,4);
   param.Value = 15;
   cmd.Parameters.Add(param);
   conn.Open();
   //当关闭reader的时候同时关闭数据库连接
   SqlDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
   while(reader.Read())
   {
    Console.WriteLine("Name:{0} PhoneNum:{1} Address:{2}",reader.GetString(0),reader.GetString(1),reader.GetString(2));
   }
   showSplit();
   //无需关闭conn,系统会自动调用这个方法来关闭conn的。
   reader.Close();

   //**************************************
   //*演示带参数查询的操作,使用OleDb
   //**************************************
   public void hasOledbParamReader()
   {
   SqlCommand cmd;
   cmd = conn.CreateCommand();
   string sql = "select Fname,Fphone,Faddress from friend where Fid > ?";
   string oledbConnStr = "Provider=sqloledb;" + connStr;
   OleDbConnection oleConn = new OleDbConnection(oledbConnStr);
   OleDbCommand oleCmd = new OleDbCommand(sql,oleConn);
   oleCmd.Parameters.Add("nothing",15);
   oleConn.Open();
   OleDbDataReader oleReader = oleCmd.ExecuteReader();
   while(oleReader.Read())
   {
    Console.WriteLine("Name:{0} PhoneNum:{1} Address:{2}",oleReader.GetString(0),oleReader.GetString(1),oleReader.GetString(2));
   }
   showSplit();
   oleReader.Close();
   oleConn.Close();
   }
  
   //**************************************
   //*演示存储过程的输出参数
   //**************************************
   public void outParamShow()
   {
   SqlCommand cmd;
   cmd = conn.CreateCommand();
   cmd.CommandText = "GetInfo";
   cmd.CommandType = CommandType.StoredProcedure;
   SqlParameter param = cmd.Parameters.Add("@Fid",16);
   param = cmd.Parameters.Add("@Fname",SqlDbType.VarChar,8);
   param.Direction = ParameterDirection.Output;
   param = cmd.Parameters.Add("@Fphone",SqlDbType.VarChar,8);
   param.Direction = ParameterDirection.Output;
   conn.Open();
   cmd.ExecuteNonQuery();
   string Fname = cmd.Parameters["@Fname"].Value.ToString();
   string Fphone = cmd.Parameters["@Fphone"].Value.ToString();
   Console.WriteLine(Fname + " " + Fphone);
   conn.Close();
   showSplit();

   //**************************************
   //*演示读取多个无关记录集
   //**************************************
   public void multiResult()
   {
   SqlCommand cmd;
   cmd = conn.CreateCommand();
   string sqla = "select Fname from friend";
   string sqlb = "select Fphone from friend";
   cmd.CommandText = sqla + ";" + sqlb;
   conn.Open();
   SqlDataReader reader= cmd.ExecuteReader();
   int i = 1;
   do
   {
    Console.WriteLine("第" + i.ToString() + "个记录集内容如下: ");
    while(reader.Read())
    {
    Console.WriteLine(reader[0].ToString() + " ");
    }
    i++;
   }while(reader.NextResult()); //NextResult()移动到下一个记录集
   reader.Close();
   conn.Close();
   showSplit();
   }
  
   //**************************************
   //*使用DataReader获得数据库模式信息
   //**************************************
   public void getSchema()
   {
   SqlCommand cmd;
   cmd = conn.CreateCommand();
   string sql = "select Fid,Fname,Fphone from friend";
     cmd.CommandText = sql;
     conn.Open();
     SqlDataReader reader = cmd.ExecuteReader();
     DataTable SchemaTable = reader.GetSchemaTable();
    
     DataRowCollection SchemaColumns = SchemaTable.Rows;
     DataColumnCollection SchemaProps = SchemaTable.Columns; 
     foreach(DataRow SchemaColumn in SchemaColumns)
     {
     foreach(DataColumn SchemaColumnProp in SchemaProps)
     {
      Console.WriteLine(SchemaColumnProp.ColumnName + "=" + SchemaColumn[SchemaColumnProp.ColumnName].ToString());
     }
     }
     reader.Close();
     conn.Close();
     showSplit();

   //**************************************
   //*从数据库读取二进制数据的代码段
   //*该代码段只是读取二进制的片断,不是
   //*整个程序,所以不能执行,你可以把它
   //*集成到你的WinForm项目里面。
   //**************************************
   public void getBinary()
   {
   /*
   System.IO.MemoryStream stream = new System.IO.MemoryStream();
   System.IO.BinaryWriter writer = new System.IO.BinaryWriter(stream); 
   int BufferSize = 1024;
   byte[] Buffer = new Byte[BufferSize];
   long Offset = 0;
   long BytesRead = 0;
   do
   {
    BytesRead = reader.GetBytes(2,Offset,Buffer,0,BufferSize);
    writer.Writer(Buffer,0,(int)BytesRead);
    writer.Flush();
    Offset += BytesRead;
   }
   while(BytesRead == BufferSize);
   */
   }
  
   //添加输出分隔
   private void showSplit()
   {
   Console.WriteLine(" ******************************************************************** ");
   }
  
   public static void Main(string [] args)
   {
   SqlReader sqlreader = new SqlReader();
   
   sqlreader.basicReader();
   
   sqlreader.hasParamReader();
   
   sqlreader.hasOledbParamReader();
   
   sqlreader.outParamShow();
   
   sqlreader.multiResult();
   
   sqlreader.getSchema();

 

 

 

上下文章:

 

上一篇文章: 如何判断程序处于运行环境还是调试环境 下一篇文章: 程序员英语试题常见硬件名和设备名

相关文章:

  • AV杀手变种强行关闭杀度软件与下载恶意程序
  • [Oracle]Oracle10g闪回恢复区详细解析
  • Oracle数据库的备份及恢复策略研究(4)完
  • Oracle10g闪回恢复区详细解析
  • Oracle认证考试详细介绍

相关软件:

  • 华娱网电影程序 v1.0版
  • 武汉娱乐网翻唱程序
  • 极限音乐网全站程序
  • 林州数码港FLASH程序
  • 中国电台网web程序
  • 做好娱乐免费电影程序 v1.0

 

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

认证考试分类导航

  • 微软认证
  • 计算机等级考试
  • 软件水平考试
  • 思科认证
  • Oracle认证
  • Linux认证
  • JAVA认证
  • 网络工程师
  • 系统工程师
  • 程序员

本类经典文章推荐

  • 软考系统分析师考试须知
  • C++箴言:绝不在构造或析构期调用...
  • 数据结构:判别是否为二叉排序树的...
  • 一个程序员的成长的六个阶段
  • 程序员英语试题常见硬件名和设备名
  • 从一个程序出发详细研究DataReader
  • 如何判断程序处于运行环境还是调试...
  • 程序高手必读:写好C程序的10条秘...
  • 程序员介绍:程序员的“素质”是什...
  • C++箴言:让=返回一个*this的引用

程序员阅读排行

  • 数据结构:判别是否为二叉排序树的...
  • VC++动态链接库(DLL)编程深入浅出...
  • VC++动态链接库(DLL)编程深入浅出...
  • 程序员考试:证书样本
  • 补码加、减运算规则及溢出判断
  • 数据结构:栈和递归求两顶点所有简...
  • 水滴石穿·C语言之代码检查工...
  • DirectX8.0简介(3)
  • 数据结构:打印线索二叉树的中序遍...
  • DirectX8.0简介(8)

认证考试阅读总排行

  • 全国计算机等级考试一级模拟试题01
  • 全国计算机等级考试一级模拟试题10
  • 全国计算机等级考试一级模拟试题08
  • MCSD简介
  • 全国计算机等级考试一级考试最新模...
  • 全国计算机等级考试一级模拟试题07
  • 全国计算机等级考试一级模拟试题02
  • 全国计算机等级考试一级模拟试题06
  • 全国计算机等级考试一级模拟试题03
  • 一级(WINDOWS)试题解析-Word篇

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有