2

如果我尝试读取 Access 2013 数据库的架构,则会收到以下错误:

no read permission on 'MSysRelationships'

现在帮助告诉我

User-level security features are not available in Access apps, web databases, 
or databases that use one of the new file formats (.accdb, .accde, .accdc, .accdr).

=> 如何读取该数据库的架构?

编辑 :

这是我在 Linqpad 中的代码:

var stringBuilder = new OleDbConnectionStringBuilder();
stringBuilder.Provider = "Microsoft.ACE.OLEDB.12.0";
stringBuilder.DataSource = @"C:\Recommendations.accdb";

using (var connection = new OleDbConnection(stringBuilder.ToString().Dump()))
{
    connection.Open();
    var schemaTable = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] {null, null, null, "TABLE"});
    var sheetName = schemaTable.AsEnumerable().Select(row => row.Field<string>("TABLE_NAME")).First();
    schemaTable.Dump();

    string  namesQuery = "SELECT DISTINCT szRelationship, szReferencedObject, szObject FROM MSysRelationships";
    string  namesQuery2 =  string.Format("select Name, Age from [{0}]", "Users");

    using (var command = new OleDbDataAdapter(namesQuery, connection))
    {
        var dataSet = new DataSet();
        command.Fill(dataSet, sheetName);
        dataSet.Dump();
    }
    connection.Close();
}
4

2 回答 2

2

从对此处类似的较早问题的回答来看,我怀疑您根本无法通过 OleDb 连接直接读取 Access 中的系统表。但是,您也许可以通过该OleDbConnection.GetSchema方法获得所需的信息(详情请点击此处)。

于 2013-03-19T18:53:56.620 回答
2

在连接字符串中,设置“用户 ID=管理员”。

使用 Access 打开数据库,按 Ctrl-G 得到“立即”窗口,然后执行以下命令:

CurrentProject.Connection.Execute "GRANT SELECT ON MSysRelationships TO Admin;"

这将授予“用户 ID”从该表中读取 (SELECT) 的权限。这同样适用于其他系统表,如“MSysObjects”。

于 2017-06-29T10:40:18.283 回答