找回密码
 注册
搜索
热搜: 回贴

ASP.net:用DataReader读取数据到ListView当中

2009-12-13 13:30| 发布者: admin| 查看: 52| 评论: 0|原作者: 天仙子

●对DataReader可能大家都已经很熟......


对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当中。

最新评论

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-29 23:28 , Processed in 0.117370 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

返回顶部