如何用vba编写一个抽取oracle数据库表数据,把表的表名,字段名,数据显示在一个新建的excel页中,要求需要:需要抽取的库名从excel的Sheet1中A1获取,数据库的账号在Sheet1中A2获取,数据库的密码在Sheet1中A3获取,要抽取数据的表名在Sheet1中A4获取,抽取数据的WHERE条件在Sheet1中A5获取,并且在Sheet1中A6的位置设计一个开始执行程序的按钮
时间: 2024-03-09 08:48:50 浏览: 71
以下是一个简单的VBA代码,可以实现你的需求:
```vba
Sub ExtractDataFromOracle()
Dim con As Object
Set con = CreateObject("ADODB.Connection")
'从Sheet1中获取参数
Dim dbName As String
dbName = Sheets("Sheet1").Range("A1").Value
Dim dbUser As String
dbUser = Sheets("Sheet1").Range("A2").Value
Dim dbPassword As String
dbPassword = Sheets("Sheet1").Range("A3").Value
Dim tableName As String
tableName = Sheets("Sheet1").Range("A4").Value
Dim whereClause As String
whereClause = Sheets("Sheet1").Range("A5").Value
'连接Oracle数据库
con.Open "Driver={Oracle in OraClient11g_home1};Dbq=" & dbName & ";Uid=" & dbUser & ";Pwd=" & dbPassword & ";"
'执行SQL查询
Dim rs As Object
Set rs = CreateObject("ADODB.Recordset")
rs.Open "SELECT * FROM " & tableName & " WHERE " & whereClause, con
'将结果写入新建的Excel页
Dim wb As Workbook
Set wb = Workbooks.Add
Dim ws As Worksheet
Set ws = wb.Sheets(1)
Dim i As Integer
For i = 0 To rs.Fields.Count - 1
ws.Cells(1, i + 1).Value = rs.Fields(i).Name
Next i
ws.Range("A2").CopyFromRecordset rs
'关闭连接
rs.Close
con.Close
End Sub
```
在Sheet1中添加一个按钮,然后将其绑定到这个VBA宏即可。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/10214/10214c21be157c7ee09c5af8793db42d5f2aee45" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/a56b5/a56b5979fe0116496be415a8d78dd25dd7563ea9" alt="application/x-rar"
data:image/s3,"s3://crabby-images/c6620/c6620e5b8e26c517a2d88e36fa018e7d860be935" alt="xlsx"
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt=""
data:image/s3,"s3://crabby-images/a56b5/a56b5979fe0116496be415a8d78dd25dd7563ea9" alt="application/x-rar"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt=""
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt=""
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"