热门文章
 
SQL SERVER 和AC
判断access数据库中某个
Access数据库的存储上限
Access2000数据库8
论ACCESS的性能
ASP+ACCESS 无限级
asp中使用access的系
以编程方式创建“自动编号”字
通用删除某表某字段满足条件的
使用中型Access数据库的
 推荐文章
 
asp中使用access的系
深入了解 Microsoft
ACCESS中使用SQL语句
一句代码得到表中的某行的指定
保护Access数据库的安全
使用中型Access数据库的
通用删除某表某字段满足条件的
以编程方式创建“自动编号”字
Access 数据库表规格
ASP+ACCESS 无限级
判断access数据库中某个
Access2000数据库8
Access数据库的存储上限
SQL SERVER 和AC
access能隐藏表而不出现
ACCESS技巧集
 
你现在的位置:您现在的位置是: 中国ASP>>数据库>>access
asp中使用access的系统表的方法

下面是获取数据表的方法:



方法一:直接用ado的OpenSchema()方法打开adSchemaTables,建立一个schema记录集

<%
Const adSchemaTables = 20
adSchemaColumns = 4
dim Conn,db
dim ConnStr
db="temp.mdb" 'ACCESS数据库的文件名,请使用相对于网站根目录的的绝对路径
ConnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(db)
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open connstr

Dim rstSchema
Dim I

Set rstSchema = Conn.OpenSchema(adSchemaTables)

Do while not rstSchema.EOF
response.write("Table name: "& rstSchema("TABLE_NAME") & vbCr & _
"Table type: " & rstSchema("TABLE_TYPE") & vbCr)
response.write("<br/>")
I = I + 1
rstSchema.MoveNext
Loop
rstSchema.Close

conn.Close
%>

方法二:Access 系统表 MsysObjects 包含了数据库对象列表。尽管未在文档中记载,你仍可通过查询它来获取你想要的。但是默认情况下无法操作系统表,必须手动设定权限收才能查询系统表。
请参考以下动画:如何获取对msysobject的操作权限 http://blog.iyi.cn/user/david/archives/IMAGES/msobject.swf

但是我在access2003中找不到这几个系统表,不知道是不是m$增强了access的安全性。

使用下列 SQL 语句来获取你想要的

查询:
SELECT MSysObjects.Name FROM MsysObjects WHERE (Left([Name],1)<>"~") AND (MSysObjects.Type)=5 ORDER BY MSysObjects.Name;


窗体:
SELECT MSysObjects.Name FROM MsysObjects WHERE (Left([Name],1)<>"~") AND (MSysObjects.Type)=-32768 ORDER BY MSysObjects.Name;


表:
SELECT MSysObjects.Name FROM MsysObjects WHERE (Left([Name],1)<>"~") AND (Left$([Name],4) <> "Msys") AND (MSysObjects.Type)=1 ORDER BY MSysObjects.Name;


报表:
SELECT MSysObjects.Name FROM MsysObjects WHERE (Left([Name],1)<>"~") AND (MSysObjects.Type)= -32764 ORDER BY MSysObjects.Name;


模块:
SELECT MSysObjects.Name FROM MsysObjects WHERE (Left([Name],1)<>"~") AND (MSysObjects.Type)= -32761 ORDER BY MSysObjects.Name;


宏:
SELECT MSysObjects.Name FROM MsysObjects WHERE (Left([Name],1)<>"~") AND (MSysObjects.Type)= -32766 ORDER BY MSysObjects.Name;



相关信息:

在 Access 中使用“存储过程”
SQL SERVER 和ACCESS/excel的数据导入导出
判断access数据库中某个表是否存在
Access数据库的存储上限
Access2000数据库80万记录通用快速分页类
论ACCESS的性能
ASP+ACCESS 无限级目录树
asp中使用access的系统表的方法

 

中国ASP技术 ASP.ORG.CN 版权所有 2004-2008