不从数据库中检索数据

时间:2013-02-12 02:35:49

标签: c# oledb

我已经尝试构建并运行此代码,但它始终向我发送错误:'导致无法从数据库中检索数据。

我构建它后,我的代码没有错误。我一直在寻找,但我看不出有什么不妥。

我希望能为这种情况找到答案。感谢

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;


namespace WindowsFormsApplication1
{

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {    
        }

        private void listView1_SelectedIndexChanged(object sender, EventArgs e)
        {        
        }

        private void button1_Click(object sender, EventArgs e)
        {

            string ProviderName = null;
            string CatalogName = null;
            string DataSourceName = null;
            string ConnectionString = null;
            string CommandString = null;
            const int MaxRows = 100;

            ProviderName = "Provider=Something;";
            CatalogName = "Catalog=Something;";
            DataSourceName = "DataSource=Something";

            ConnectionString = ProviderName+CatalogName+DataSourceName;

            ////////////////////////////////////////////////////////////////////////////////

            CommandString = "Something";

            OleDbConnection DBConnection = null;
            try
            {
                DBConnection = new OleDbConnection(ConnectionString);
            }catch (Exception ex){

            MessageBox.Show("Error: Not connected. \n{0}", ex.Message);
                return;
            }

            try
            {
                OleDbCommand DBCommand = new OleDbCommand(CommandString, DBConnection);
                DBConnection.Open();


                OleDbDataReader DBReader = DBCommand.ExecuteReader();

                    /////////////////////////////////////////////////////////////////////////

                DateTime DBTimestamp = new System.DateTime();
                Double DBValue = new System.Double();
                int DBQualityCode;
                int DBFlags;
                String ColumnEntry;

                listView1.View = View.Details;
                listView1.GridLines = true;
                listView1.TabIndex = 0;
                listView1.Width = 400;

                listView1.Columns.Add(new ColumnHeader());
                listView1.Columns[0].Text = ("Timestamp");
                listView1.Columns[0].TextAlign = (HorizontalAlignment.Center);
                listView1.Columns[0].Width = 150;


                listView1.Columns.Add(new ColumnHeader());
                listView1.Columns[1].Text = ("Value");
                listView1.Columns[1].TextAlign = (HorizontalAlignment.Center);
                listView1.Columns[1].Width = 60;


                listView1.Columns.Add(new ColumnHeader());
                listView1.Columns[2].Text = ("Quality Code");
                listView1.Columns[2].TextAlign = (HorizontalAlignment.Center);
                listView1.Columns[2].Width = 60;


                listView1.Columns.Add(new ColumnHeader());
                listView1.Columns[3].Text = ("Flags");
                listView1.Columns[3].TextAlign = (HorizontalAlignment.Center);
                listView1.Columns[3].Width = 60;

                ListViewItem SingleRow;

                int count = 0;

                //////////////////////////////////////////////////////////////////////////

               while ((DBReader.Read() && (count < MaxRows)))
                {
                    DBTimestamp = DBReader.GetDateTime(1);
                    DBValue = DBReader.GetDouble(2);
                    DBQualityCode = DBReader.GetInt32(3);
                    DBFlags = DBReader.GetInt32(4);

                    //////////////////////////////////////

                    ColumnEntry = String.Format("{0:dd.MM.yy HH:mm:ss}{1:D2}", DBTimestamp, DBTimestamp.Millisecond);
                    SingleRow = new ListViewItem(ColumnEntry);

                    ColumnEntry = String.Format("{0:F}", DBValue);
                    SingleRow.SubItems.Add(ColumnEntry);

                    ColumnEntry = String.Format("{0:X2}", DBQualityCode);
                    SingleRow.SubItems.Add(ColumnEntry);

                    ColumnEntry = String.Format("{0:X4}", DBFlags);
                    SingleRow.SubItems.Add(ColumnEntry);

                    listView1.Items.Add(SingleRow);

                    count = count + 1;
               }
               DBReader.Close();
            }
            catch (Exception ex)
            {

                MessageBox.Show("Error:Failed to retrive Data From Database. \n{0}", ex.Message);
            }
            finally
            {

                DBConnection.Close();

            }    
                //////////////////////////////////////////////////

        }
    }
}

0 个答案:

没有答案