我很难设置我的OleDb连接

时间:2012-12-12 18:33:57

标签: c# oledb

您好我正在尝试建立与数据源的连接并提取信息并将其显示在网格视图中。问题是我总是得到ada的null值。是否有可能错误输入查询或适配器有问题?

此外,我使用myInt变量插入不同的数据源,因为我要处理多个文件,也许这可能会有问题。

try
            {
                //establish connectioin
                OleDbConnection conn = new OleDbConnection(("provider=Microsoft.Jet.OLEDB.4.0; " + ("data source=" + myInt + ";" + "Extended Properties=Excel 8.0;")));

               OleDbDataAdapter ada = new OleDbDataAdapter("SELECT * FROM MarkingSheet$]", conn);

                DataSet ds = new DataSet();

               ada.Fill(ds);
               dataGridView1.DataSource = ds.Tables[0].DefaultView;

               conn.Close();
            }

ANSWER 这对我有用吗

OleDbConnection conn = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + myPath + ";Excel 12.0;HDR=YES;"); ;
              conn.Open();
              OleDbDataAdapter ada = new OleDbDataAdapter("select * from [Marking Sheet$]", conn); ;
               DataSet ds = new DataSet();
               ada.Fill(ds);

2 个答案:

答案 0 :(得分:0)

将sql更改为

"SELECT * FROM [MarkingSheet$]"

因为缺少开场支架。

答案 1 :(得分:0)

代码中的错误是您在尝试填充适配器时没有打开连接。你的SQL语句也错了。您可能也希望将DataTable绑定到DataGridView,如下所示: -

 try
     {

         OleDbConnection conn = new OleDbConnection(("provider=Microsoft.Jet.OLEDB.4.0; " + ("data source=" + myInt + ";" + "Extended Properties=Excel 8.0;")));

         OleDbDataAdapter ada = new OleDbDataAdapter("SELECT * FROM [MarkingSheet$]", conn);

         DataSet ds = new DataSet();

         conn.Open();             

         ada.Fill(ds.Tables[0]);

         conn.Close();

         BindingSource bs = new BindingSource();
         bs.Datasource = ds.Tables[0];

         dataGridView1.DataSource = bs;

      }
  catch(OledbException x)
      {
        // Handle Exception
      }

编辑 * *

尝试将连接字符串更改为: -

string connString = "provider=Microsoft.Jet.OLEDB.4.0;Data source=" + myInt + ";Extended Properties=Excel 8.0;HDR=Yes;IMEX=1\";";