T-SQL判断某个表在ACCESS中是否存在及查看ACCESS中的系统表
2009-08-27 15:37
246 查看
如何用T-SQL判断某个表在ACCESS中是否存在,也就是如何用T-SQL显示access的用户表,其实access有一个隐藏了类似于sysobjects的系统表,并且必须设置权限才可以访问得到。
环境:SQL SERVER 2005,ACCESS97(不行), ACCESS2000为更高版本
首先,我们让类似于MSSQL的几个系统表显示出来,点击工具->选项->视图->系统对象前面打上勾,点击确定,你会发现在对象->表下面多出5个MS打头的表,这是就隐藏的系统表。
接着,我们如果在查询分析器中运行:
select name from OpenRowSet('microsoft.jet.oledb.4.0',';database=Access文件路径','select * from MSysObjects')
会报错如下: 消息 7357,级别 16,状态 2,第 1 行 无法处理对象 "select * from MSysObjects"。链接服务器 "(null)" 的 OLE DB 访问接口 "microsoft.jet.oledb.4.0" 指示该对象没有列,或当前用户没有访问该对象的权限。
其实这是因为没有权限的原因造成的,那么我们打开这个操作权限,工具->安全->用户与组安全->选表msysobjects,设定权限,点确定后再运行上面的语句就OK了。
环境:SQL SERVER 2005,ACCESS97(不行), ACCESS2000为更高版本
首先,我们让类似于MSSQL的几个系统表显示出来,点击工具->选项->视图->系统对象前面打上勾,点击确定,你会发现在对象->表下面多出5个MS打头的表,这是就隐藏的系统表。
接着,我们如果在查询分析器中运行:
select name from OpenRowSet('microsoft.jet.oledb.4.0',';database=Access文件路径','select * from MSysObjects')
会报错如下: 消息 7357,级别 16,状态 2,第 1 行 无法处理对象 "select * from MSysObjects"。链接服务器 "(null)" 的 OLE DB 访问接口 "microsoft.jet.oledb.4.0" 指示该对象没有列,或当前用户没有访问该对象的权限。
其实这是因为没有权限的原因造成的,那么我们打开这个操作权限,工具->安全->用户与组安全->选表msysobjects,设定权限,点确定后再运行上面的语句就OK了。
相关文章推荐
- SQL中用系统存储过程xp_fileexist来判断文件是否存在
- 用 Sql添加删除字段,判断字段是否存在的方法
- MS SQL SERVER 2008 使用OBJECT_ID判断临时表是否存在
- 判断MS SQLSERVER临时表是否存在
- 【转载】C int access(const char *path, int amode); 判断文件是否存在
- linux下的access()函数判断文件是否存在、打印时间
- [转]SQL判断临时表是否存在
- 【转】如何判断SQL中是否已经存在某表、存储过程、函数等
- 摘录:java和sql如何判断数据库是否存在
- linux下的access()函数判断文件是否存在、打印时间
- SQL判断临时表是否存在
- 在SQL中判断一个表是否存在
- sql 判断 函数 存储过程是否存在的方法
- SQL数据是否存在(是否有数据)判断,表,存储过程是否存在
- 用SQL语句判断数据库中的记录是否存在
- SQL中判断对象是否存在
- access判断表是否存在
- sql 2005判断某个表或某个表中的列是否存在
- SQL脚本判断数据库、函数、 存储过程等是否存在的方法
- sql 判断 数据库 表 字段 是否存在