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


Author: 胡林

Date: 2008年10月25日 00:56:00

1.	select name 
2.
3. from
4.
5. OpenRowSet('microsoft.jet.oledb.4.0',';database=c:/db1.mdb','select * from MSysObjects')
6.

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

     环境:SQL SERVER 2005 ,ACCESS2000

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

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

报错如下:

消息 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 内的用户表。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值