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

来源:计算机等级考试    发布时间:2012-08-28    计算机等级考试视频    评论

  如何用TSQL判断某个表在ACCESS中是否存在,也就是如何用tsql显示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内的用户表。

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答