用DataReader读取数据到ListView当中

王朝other·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

对DataReader可能大家都已经很熟悉了,但是我还是推荐大家读一下这篇文章。下载源文件:Download demo project - 71 Kb

这篇文章的原出处是:http://www.codeproject.com/dotnet/adonet_datareader.asp,我把其中的大概意思反译过来,以帮助正在学习ADO.NET的广大网友。

上图是该Project运行后的效果图。

这个Project的意图就是把数据库当中某个表数据通过DataReader读取到ListView当中去,并且显示其结果和状态信息。当然我们还可以纵深运用,通过对SQL Query的更改来达到一种完全的交互,而不限于一个已知数据库及表等。

我们有必要介绍一下有关的几个DataReader的属性:

FieldCount:查询记录当中的字段个数。

Read():返回一个布尔值,可以用来判断DataReader是否读取到记录

NextResult(),在用Command对象执行多个记录集时用到,将会读取下一个记录集

这个Project非常的简单,下面就是在点击了Read Table按钮后时的Code:

OleDbConnection Connection = new OleDbConnection ();

try

{

// Open a connection to the database

Connection.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName.Text + ";" +

"Persist Security Info=False;";

Connection.Open();

// Create an OleDb command,

OleDbCommand command = new OleDbCommand();

command.Connection = Connection;

command.CommandText = "SELECT * FROM Authors";

// Execute and return the rows in the data reader object

OleDbDataReader dataReader;

dataReader = command.ExecuteReader(CommandBehavior.CloseConnection);

int nFields = dataReader.FieldCount;

// Setup the columns in the listview using the fields in the table

listView.Clear();

for (int i = 0; i < nFields; i++)

{

listView.Columns.Add(dataReader.GetName(i), 100,

HorizontalAlignment.Left);

}

// Fill the rows in the listview using the data in the rows

int nRow = 0;

while (dataReader.Read())

{

// Create an array of subitems for quick insertion

// The subitems will be all fields in the row except for

// the first field

String [] subitems = new String[nFields];

for (int i = 0; i < nFields; i++)

{

subitems[i] = dataReader[i].ToString();

}

// Insert a new item into the listview, and add the subitems at

// the same time. The item will be the first field in the row

ListViewItem item = new ListViewItem(subitems, -1);

listView.Items.Add(item);

++nRow;

}

dataReader.Close();

// Set the status text

StatusText.Text = nFields.ToString() + " columns, " +

nRow.ToString() + " rows read";

}

catch (Exception ex)

{

// If an error occured alert the user

StatusText.Text = "Error: " + ex.Message;

}

finally

{

// Close the connection if necessary

if (Connection.State == System.Data.ConnectionState.Open)

Connection.Close();

}

这段代码就是把数据表当中的内容加入到ListView当中去,这里面用到了DataReader.FieldCount属性来控制ListView当中的Columns,通过对FieldCount的循环,利用DataReader.GetName()来把字段名称加入到ListView当中。

接下来我们通过循环把DataReader当中的记录通过循环读取到了数组当中,然后通过ListViewItem(subitems,-1)把其加入到ListView当中。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航