热点推荐:ASP.Net | ADO.Net | VB.Net | Web服务器 | Access | MSSQL | MySQL | Oracle | .Net控件 | Win 9x | Win 2000 | Win 2003 | DOS | Unix | 注册表 | 应用其它 | 安装调试 | 基本操作 | 使用技巧 | 系统优化 |故障处理 | 个性风格 | 病毒安全 | 专杀工具
您现在的位置: 中华IT技术网 >> 数据库 >> ACCESS >> 正文
全文
如何取得Access数据库中的所有用户表和视图
作者:1024k    文章来源:本站原创    更新时间:2007-9-22

方法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。

  • 上一篇文章:
  • 下一篇文章: 没有了
  • 相关文章
    最新更新
    编辑推荐
    热门图片
    频道大全
    文章阅读排行
    周排行
    月排行