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