点击这里给我发消息 点击这里给我发消息
首页 > 行业资讯 > Access>详细内容

T-SQL查询access的数据表名的列表

添加时间:2011-6-25
    相关阅读: SQL MSSQL 链接 系统

今天打开CSDN发一个网友问我如何用T-SQL判断某个表在ACCESS中是否存在,也就是如何用t-sql显示access的用户表,其实access有一个隐藏了类似于sysobjects的系统表,并且必须设置权限才可以访问得到,下面我写出我测试的过程:

  环境:SQL SERVER 2005,ACCESS2000

  首先,我们让类似于MSSQL的几个系统表显示出来,点击工具->选项->视图->系统对象前面打上勾,点确定,你会发现在对象->表下面多出5个MS打头的表,这是就隐藏的系统表。

  接着,我们如果在查询分析器中运行:

  select name

  from

  OpenRowSet('microsoft.jet.oledb.4.0',';database=c:\db1.mdb','select * from MSysObjects')

  报错如下:

  消息 7357,级别 16,状态 2,第 1 行

  无法处理对象 "select * from MSysObjects"。链接服务器 "(null)" 的 OLE DB 访问接口 "microsoft.jet.oledb.4.0" 指示该对象没有列,或当前用户没有访问该对象的权限。

  其实这是因为没有权限的原因造成的,那么我们打开这个操作权限,工具->安全->用户与组安全->选表msysobjects,设定权限,点确定后再运行上面的语句看看,

  select name

  from

  OpenRowSet('microsoft.jet.oledb.4.0',';database=c:\db1.mdb','select * from MSysObjects')

  where type = 1 and flags = 0

  /*

  name

  ------------------------------------------------------------------------------------------

  ta

  Switchboard Items

  myclass

  ta1

  ta2

  (5 行受影响)

  */

  注:以上我测试的ACCESS内的用户表

本文作者:未知
咨询热线:020-85648757 85648755 85648616 0755-27912581 客服:020-85648756 0755-27912581 业务传真:020-32579052
广州市网景网络科技有限公司 Copyright◎2003-2008 Veelink.com. All Rights Reserved.
广州商务地址:广东省广州市黄埔大道中203号(海景园区)海景花园C栋501室
= 深圳商务地址:深圳市宝源路华丰宝源大厦606
研发中心:广东广州市天河软件园海景园区 粤ICP备05103322号 工商注册