zoukankan      html  css  js  c++  java
  • 如何取得Access数据库中的所有用户表和视图

    方法1 对数据库文件进行特殊的处理:
    打开数据库文件
    工具->选项
    然后把系统对象和隐藏对象都设置出来:
    DBProperties.JPG

    这样你就会看到系统表了:
    MSysObjects表中就是类似SQLServer里的系统表,里面记录了所有的用户表,视图等一些信息,只用查询它就行了。
    SQL语句:"select [Name] as [TABLE_NAME],[Flags],[Type] from [MSysObjects] where [Flags]=0 and [Type]=1";

    然而默认情况下,你的应用程序是没有权限来读取这张表的(是的,读的权限都没有)。
    因此,在读这张表之前要先设置权限:
    工具->安全->用户与组的权限
    DBProperties2.JPG
    将读权限勾上就行了。

    然而,更多时候我们并不能保证所有的数据文件对MSysObjects都有读权限,而且每次设置一下也很麻烦。

    方法2:
    利用OLEDB的系统API来解决这个问题,当然.Net的OleDBConnection已经为我们封装好了。
    DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] {null, null, null, "TABLE"});
    一句就可以搞定了。当然,同样的方法也可以读取视图。 详细的信息请查看MSDN。

  • 相关阅读:
    HDU 1730 类NIM模型
    HDU 4315 阶梯博弈变形
    HDU 3389 阶梯博弈变形
    HDU 1524 树上无环博弈 暴力SG
    HDU 3094 树上删边 NIM变形
    vim的安装与配置
    Apache Mysql 搭配详解
    [置顶] 博客转移
    “玲珑杯”线上赛 Round #15 河南专场 C 咸鱼魔法记
    “玲珑杯”线上赛 Round #15 河南专场 F 咸鱼文章
  • 原文地址:https://www.cnblogs.com/WuCountry/p/853774.html
Copyright © 2011-2022 走看看