在VB中怎样得到一个ACCESS2000数据库中的所有表名,急!在线等待!高分相赠!

zhhaidong 2003-10-09 08:55:22
在VB中怎样得到一个ACCESS2000数据库中的所有表名?

我要做的操作是在一个按钮中实现访问一个ACCESS2000的数据库,并得到库中的所有表的名字和表中记录的个数。

在线等待、、、
高分相赠!!!
...全文
199 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
yunfeng007 2003-10-09
  • 打赏
  • 举报
回复
娃哈哈!
NotReady 2003-10-09
  • 打赏
  • 举报
回复
Dim cn As New ADODB.Connection
Dim rs As New ADODB.Recordset
cn.CursorLocation = adUseClient
cn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\aa\Finished_kjkw\sc\Data.mdb;Persist Security Info=False"
cn.Open
Set rs = cn.OpenSchema(adSchemaTables)
Do While Not rs.EOF
If LCase(rs!table_type) = "table" Then MsgBox rs!table_name
rs.MoveNext
Loop
MSSQL 2003-10-09
  • 打赏
  • 举报
回复
来晚了。
itlive 2003-10-09
  • 打赏
  • 举报
回复
dim cn as new adodb.connection
dim rs as new adodb.recordset
cn.connectionstring="provider=microsoft.jet.4.0;datasource=ip\path\tablename"
cn.open
set rs=cn.openschema(adschematables)
do while not rs.eof then
if rs!table_type="table" then

msgbox rs!table_name
rainstormmaster 2003-10-09
  • 打赏
  • 举报
回复
来晚了
haipingma 2003-10-09
  • 打赏
  • 举报
回复
'工程--->引用--->Microsoft DAO 3.6 Object Liarbry
Dim DaoDb As DAO.Database
Dim DaoTb As DAO.TableDef
Set DaoDb = OpenDatabase(gstrAppPath & "SysUpdate.mdb")
For Each DaoTb In DaoDb.TableDefs
msgbox DaoTb.name
Next
northwolves 2003-10-09
  • 打赏
  • 举报
回复
'引用adox
Sub disptables(mydbpath As String) '显示指定数据库中所有表名
Dim msg As String
Dim mycat As New ADOX.Catalog
msg = ""
Set mycat.ActiveConnection = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & mydbpath & ";"
For i = 0 To mycat.Tables.Count - 1
If Left(mycat.Tables.Item(i).Name, 4) <> "MSys" Then '去掉系统表
msg = msg & mycat.Tables.Item(i).Name & vbCrLf
End If
Next
MsgBox msg
End Sub
Fengq 2003-10-09
  • 打赏
  • 举报
回复
Dim cn As New ADODB.Connection, rs As New ADODB.Recordset

Set rs = cn.OpenSchema(adSchemaTables)

Do Until rs.EOF
If Trim(rs!TABLE_TYPE) = "TABLE" Then MsgBox Trim(rs!TABLE_NAME)
rs.MoveNext
Loop
射天狼 2003-10-09
  • 打赏
  • 举报
回复
还是李版主快啊~~
射天狼 2003-10-09
  • 打赏
  • 举报
回复
Dim cn As New ADODB.Connection
cn.ConnectionString = "dsn=" & cboDSN1.Text & ";uid=" & txtUID1.Text & ";pwd=" & txtPWD1.Text
cn.Open

Set rs = cn.OpenSchema(adSchemaTables)

lstTable1.Clear

lblStatus1.Caption = "数据源连接成功,正在检索数据表..."

DoEvents

Do Until rs.EOF
If Trim(rs!TABLE_TYPE) = "TABLE" Then lstTable1.AddItem Trim(rs!TABLE_NAME)
rs.MoveNext
Loop

rs.Close
Set rs = Nothing
cn.close
Set cn= nothing
lihonggen0 2003-10-09
  • 打赏
  • 举报
回复
'----------------------------------------------------------------------------
'
'Author:lihonggen0
'Date:2003-6-19
'功能:获取access库中表的个数及表的名称
'用ado怎样实现
'工程--->引用--->Microsoft ActiveX Data Object 2.x(版本号)
'----------------------------------------------------------------------------
Private Sub Form_Load()
Dim adoCN As New ADODB.Connection '定义数据库的连接
Dim strCnn As New ADODB.Recordset
Dim I As Integer
str1 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\Northwind.MDB;Persist Security Info=False"
adoCN.Open str1

Set rstSchema = adoCN.OpenSchema(adSchemaTables)

Do Until rstSchema.EOF
If rstSchema!TABLE_TYPE = "TABLE" Then
out = out & "Table name: " & _
rstSchema!TABLE_NAME & vbCr & _
"Table type: " & rstSchema!TABLE_TYPE & vbCr
I = I + 1
End If
rstSchema.MoveNext
Loop
MsgBox I
rstSchema.Close

adoCN.Close
Debug.Print out
End Sub

http://expert.csdn.net/Expert/FAQ/FAQ_Index.asp?id=8159
hemeijun81 2003-10-09
  • 打赏
  • 举报
回复
学习!!!!!
juror 2003-10-09
  • 打赏
  • 举报
回复
顶顶顶顶
liaorui 2003-10-09
  • 打赏
  • 举报
回复
来晚了,来晚了。顶一下好了。
sunzhiying888 2003-10-09
  • 打赏
  • 举报
回复
lihonggen不错哦,我调试了下,很正确
online 2003-10-09
  • 打赏
  • 举报
回复
rdo也比较方便
建立odbc数据源:testrdo
Private rC As rdoConnection
Set rC = rdoEnvironments(0).OpenConnection(testrdo, rdDriverCompleteRequired, True)

For C = 0 To rC.rdoTables.Count - 1
Comboodbctable.AddItem (rC.rdoTables(C).Name)
' Set I = Combotable.AddItem(rC.rdoTables(C).Name, 1)
Next C

7,762

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧