webdn
 
  首页     免费截图     VIP会员区     广告Banner     技术文档     网站模板  
网站截图,网站每日新 !
虚拟主机
网页模板

首页 >> WebDN 技术文档 >> 网络编程 >> ASP.net 技术资料 >> 用DataReader读取数据到ListView当中

 

用DataReader读取数据到ListView当中

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

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



电话咨询:010-60520722 QQ咨询:3792656   |   583696287   |   66733350 关于WebDN  |  站点地图  |  联系我们  |  支付方式  |  友情链接
© 2004-2008 WebDN.com 版权所有. 沪ICP备05040479号