如何将MS ACCESS数据库与我的asp.net网站连接

时间:2012-07-07 05:07:45

标签: asp.net database

我正在尝试将我的MS Access Db与我的asp.net网站连接。当我运行我的代码时(仅在localhost上),它不显示任何错误或异常,但它只是等待服务器响应。 我正在关注代码:

 string connection = "Provider =Microsoft.ACE.OLEDB.12.0; datasource=I:/Adittya/test.accdb";

        string query = "select * from test";
        OleDbConnection con = new OleDbConnection(connection);
        OleDbCommand cmd = new OleDbCommand();
        cmd.CommandText = query;
        cmd.CommandType = CommandType.Text;
        OleDbDataReader dr = cmd.ExecuteReader();
        DataTable dt = new DataTable();
        dt.Load(dr);

        testGrid.DataSource = dt;
        testGrid.DataBind();

我的数据库在我的笔式驱动器中的位置是静态的。

我的代码是否有问题,或者我们无法连接到笔式驱动器中的数据库。

3 个答案:

答案 0 :(得分:4)

您的代码中存在问题,您没有设置与命令对象的连接,也没有打开连接.Below代码对我有用。试试这个

    string connection = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\\Test1.accdb";

    string query = "select * from [Table]";
    OleDbConnection con = new OleDbConnection(connection);
    OleDbCommand cmd = new OleDbCommand();     
    cmd.CommandText = query;
    cmd.CommandType = CommandType.Text;
    cmd.Connection = con;
    con.Open();
    OleDbDataReader dr = cmd.ExecuteReader();
    DataTable dt = new DataTable();
    dt.Load(dr);
    con.Close();
    testGrid.DataSource = dt;
    testGrid.DataBind();

或尝试使用SqlDataSource

的此解决方案

示例:我已经创建了一个测试Acess数据库,并且我使用了Sql数据源,它工作正常。试试这个解决方案

<connectionStrings>       
    <add name="ConnectionString" connectionString="Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\Test1.accdb"
        providerName="System.Data.OleDb" />
  </connectionStrings>
 <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$     ConnectionStrings:ConnectionString %>" ProviderName="<%$ ConnectionStrings:ConnectionString.ProviderName %>" SelectCommand="SELECT * FROM [Table]"></asp:SqlDataSource>
 <asp:GridView ID="GridView1" DataSourceID="SqlDataSource1" runat="server"></asp:GridView>

这对我来说很好。

答案 1 :(得分:1)

尝试将您的数据源作为

datasource=I:\\Adittya\\test.accdb

答案 2 :(得分:0)

使用此

"Provider=Microsoft.Jet.OLEDB.4.0; " + 
     "Data Source=" + Server.MapPath("Database/TestDB.mdb"))