Happyflystone - 无枪狙击手

No one can go back and make a brand new start.

原创 T-SQL查询access的数据表名的列表收藏

新一篇: 测试文章效果 | 旧一篇: 常见问题 - SQL Server 2000 - 安装

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

     今天打开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内的用户表。

 

 

 

发表于 @ 2008年10月25日 00:56:00|评论(loading...)|收藏

新一篇: 测试文章效果 | 旧一篇: 常见问题 - SQL Server 2000 - 安装

评论

#hnsongbiao 发表于2008-10-25 08:28:37  IP: 125.34.243.*
版主 ,能否在查询分析器中通过SQL进行删除和建表(表是来自SQL2000中的)

现在SQL2000中有数据库KA,其中有一个表KTA,现在要利用SQL的查询分析器,在ACCESS数据库KB中执行操作,
如果KB中有TKB表,那么删除TKB表,然后将KTA表导入到KB中成为TKB表,如果KB中没有TKB表 ,那么直接将KTA
表导入到KB中成为TKB表。

简单的说,就是利用SQL2000的SQL查询分析器在ACCESS数据库中删除表和创建表。

急盼回复
发表评论  


登录
Csdn Blog version 3.1a
Copyright © 无枪狙击手