●对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当中。 |
|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏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.