分享
 
 
 

一个程序详细研究DataReader

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

//***********************************************************

//*名称:一个程序详细研究DataReader,同时显示Command用法

//*功能:演示DataReader的各项操作。

//*说明:如果需要文字说明请查看我的BLOG里面关于ado.net的文章

//*作者:雪冬寒

//*BOLG:http://blog.csdn.net/bineon

//***********************************************************

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}\tName:{1}\tPhoneNum:{2},\tAddress:{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}\tPhoneNum:{1}\tAddress:{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}\tPhoneNum:{1}\tAddress:{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() + "个记录集内容如下:\n");

while(reader.Read())

{

Console.WriteLine(reader[0].ToString() + "\t");

}

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("\n********************************************************************\n");

}

public static void Main(string [] args)

{

SqlReader sqlreader = new SqlReader();

sqlreader.basicReader();

sqlreader.hasParamReader();

sqlreader.hasOledbParamReader();

sqlreader.outParamShow();

sqlreader.multiResult();

sqlreader.getSchema();

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有