首页
/
每日頭條
/
職場
/
數據庫中新建查詢的在哪裡
數據庫中新建查詢的在哪裡
更新时间:2026-06-03 03:16:12

大家好,今日講解VBA數據庫解決方案第19講:如何在數據庫中新建一個查詢表,并在工作表中顯示出來。關于Recorsset集合的一些操作講解,在前幾講中講了很多,這裡提醒大家一點:任何對象都不是孤立存在的,要結合實際來理解。有朋友向我咨詢一些概念的問題,在寫這套資料時,我也同樣要參考很多的資料,有時要對照着英語去理解一些概念,這時往往發現很多的概念在英語中和之前人們翻譯是有是對不上的,所以理解起來很難.特别是現在的數據庫講解階段,涉及到ADO、 RDO、連接、打開、引用,單純的從概念上真的很難理解,這時我建議大家不要糾結于純概念,要從實際出發,比如:一段代碼就是一個連接,一個代碼就是一個創建,這樣有實際内容參考的去理解就可以了;再者,無論是什麼途徑,我們的目的是應用,隻要我們能達到應用,就達到了我們的目的。很多寫VBA的人都是專業人士,而我僅僅是根據多年的經驗來寫東西,會緊扣以實用為目的,目的是實用,下一個目的還是實用。

今日我們講解如何從Recorsset記錄集中根據某特定的條件形成一個數據庫中新表。在前幾講的講解中是把這些記錄直接顯示在工作表中,即顯示在EXCEL文件中,今日的内容和前面的内容有所不同,是要形成一個表,然後再顯示。

随着講解的深入,實際工作中經常會遇到的問題會逐漸的體現,大家要跟緊我,我們一起學習,這套教程和《VBA代碼解決方案》不同,有些内容是連續的,需要讀者慢慢的連續的去領會。

下面看看我們今日課題的代碼:

Sub mynzCreateView()

Dim cnADO, rsADO As Object

Dim strPath, strSQL, strViewName As String

Set cnADO = CreateObject("ADODB.Connection")

strPath = ThisWorkbook.Path & "\mydata2.accdb"

strViewName = "普通員工表"

cnADO.Open "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & strPath

Set rsADO = cnADO.OpenSchema(20, Array(Empty, Empty, strViewName, Empty))

If Not rsADO.EOF Then

MsgBox ("請注意:原有表将删除!")

strSQL = "DROP TABLE " & strViewName

cnADO.Execute strSQL

End If

strSQL = "CREATE VIEW " & strViewName _

& " AS SELECT * FROM 員工信息 " _

& "Where 職務= '員工'"

cnADO.Execute strSQL

MsgBox "查詢表創建成功!", , "創建視圖"

rsADO.Close

strSQL = "SELECT * FROM 普通員工表"

rsADO.Open strSQL, cnADO, 1, 3

For i = 0 To rsADO.Fields.Count - 1

Sheets("Sheet1").Cells(1, i 1) = rsADO.Fields(i).Name

Next i

For i = 1 To rsADO.RecordCount

For j = 0 To rsADO.Fields.Count - 1

Sheets("Sheet1").Cells(i 1, j 1) = rsADO.Fields(j)

Next j

rsADO.MoveNext

Next i

rsADO.Close

cnADO.Close

Set rsADO = Nothing

Set cnADO = Nothing

End Sub

代碼的講解:

1 If Not rsADO.EOF Then

MsgBox ("請注意:原有表将删除!")

strSQL = "DROP TABLE " & strViewName

cnADO.Execute strSQL

End If

以上代碼判斷是否存在這個表,如果存在,那麼删除。

2 strSQL = "CREATE VIEW " & strViewName _

& " AS SELECT * FROM 員工信息 " _

& "Where 職務= '員工'"

cnADO.Execute strSQL

MsgBox "查詢表創建成功!", , "創建視圖"

rsADO.Close

上述代碼創建了查詢表,并彈出對話框通知用戶。

這裡用的CREATE VIEW 就是創建視圖的意思:在 SQL 中,視圖是基于 SQL 語句的結果集的可視化的表。視圖包含行和列,就像一個真實的表。視圖中的字段就是來自一個或多個數據庫中的真實的表中的字段。我們可以向視圖添加 SQL 函數、WHERE 以及 JOIN 語句,我們也可以提交數據,就像這些來自于某個單一的表。

SQL CREATE VIEW 語法

CREATE VIEW view_name AS

SELECT column_name(s)

FROM table_name

WHERE condition

注釋:視圖總是顯示最近的數據。每當用戶查詢視圖時,數據庫引擎通過使用 SQL 語句來重建數據。

3 rsADO.Close

strSQL = "SELECT * FROM 普通員工表"

rsADO.Open strSQL, cnADO, 1, 3

For i = 0 To rsADO.Fields.Count - 1

Sheets("Sheet1").Cells(1, i 1) = rsADO.Fields(i).Name

Next i

For i = 1 To rsADO.RecordCount

For j = 0 To rsADO.Fields.Count - 1

Sheets("Sheet1").Cells(i 1, j 1) = rsADO.Fields(j)

Next j

rsADO.MoveNext

Next i

上述代碼先關閉之前的rsADO,然後新建立一個查詢的SQL,用于向工作表輸出數據

4 rsADO.Close

cnADO.Close

Set rsADO = Nothing

Set cnADO = Nothing

最後關閉連接和釋放内存。

特别注意點:在上述代碼中要注意的是在新的記錄集建立之前一定要關閉原先的記錄集,但這個時候的數據庫連接不用關閉,因為還是用的同一個數據庫。

好了,我們看看我們的運行結果:

數據庫中新建查詢的在哪裡(如何在數據庫中新建查詢表)1

看看數據庫的表:

數據庫中新建查詢的在哪裡(如何在數據庫中新建查詢表)2

今日内容回向:

1 如何建立一些查詢表?

2 查詢表建立後輸出的時候要注意什麼?

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
冷凍雞翅從哪裡來的(市場上的冷凍雞翅)
冷凍雞翅從哪裡來的(市場上的冷凍雞翅)
  大家好,我是秀廚娘,一個喜歡待在廚房裡研究美食的姑娘,每天與大家分享一道營養美味的家常菜做法,如果您也喜歡做美食,歡迎關注,我們可以互相分享自己在做美食時積累的經驗,互相學習,為家人和朋友做出更營養健康的美食。   導語:市場上的冷凍雞翅,都是從哪來的?超市員工說漏了嘴,看完你再買!   現在人們的收入高了,生活質量和生活水平也都随之提高了很多。對生活品...
2026-06-03
買豬肉時這三種白送也不要(買豬肉時隻要喊出這)
買豬肉時這三種白送也不要(買豬肉時隻要喊出這)
  導讀:最近菜場的豬肉真的比一些蔬菜便宜,比如我們平常買得最多的五花肉,10元錢就能買上1斤,而一些黑心的肉販子,為了使肉賣得更快,會把一些不好的肉推銷給一些不會挑選肉的人,如果您買到了這種肉,不管您回家怎麼做,豬肉不僅吃着腥味比較重,肉還特别柴,所以我們在買豬肉時,一定要裝作“高手”,這樣才能防止肉販子騙您!比如一般老手才明白:在買豬肉時,隻要喊出2個詞...
2026-06-03
職場最忌諱的三種心态(千萬别讓自己成為這三類人)
職場最忌諱的三種心态(千萬别讓自己成為這三類人)
  一類是乞丐思維的人,第二是玻璃心的人,第三是垃圾情緒的人,這三種人注定沒有出息,在職場中不會走的很遠,如果你有其中任何一種情緒,請你從今天開始,給自己注入正能量!   在職場中,有些人工作3年之後,可以成為經理,年薪十萬以上,但是有些人連主管都當不上,甚至有些人還在當基層員工,拿着可憐的薪水,擠公交,租房子,做一個非常可憐的人,如何從一個普通的員工蛻變成...
2026-06-03
詹姆斯在克利夫蘭呆了多久(詹姆斯為克利夫蘭這個城市做出了多少)
詹姆斯在克利夫蘭呆了多久(詹姆斯為克利夫蘭這個城市做出了多少)
     騎士老闆丹-吉爾伯特在2018年7月2日發表了聲明,感謝勒布朗-詹姆斯對球隊做出的貢獻。      “我們會永遠記得2016年6月19日的夜晚,詹姆斯率領騎士終結了52年的冠軍荒,為這座城市帶來了總冠軍獎杯。這是一座很多人都不敢想象有生之年可以親眼見到的總冠軍獎杯,這是一座将世世代代騎士球迷——無論是活着的人還是逝者——都聚集在一起的總冠軍獎杯。 ...
2026-06-03
輔助寒冰的天賦和出裝2023年(深度剖析寒冰職業史)
輔助寒冰的天賦和出裝2023年(深度剖析寒冰職業史)
     寒冰的均衡是一個曆史遺留難題,作為英雄聯盟中最古老的英雄之一,她的技能讓她既獨特又難以駕馭。作為一個遠程擁有魔法水晶箭這樣的先手技能是強大的,但她缺乏傷害輸出技能又讓她過于依靠普攻輸出傷害,但她又沒有位移來從艱難的環境中逃脫。   S1賽季      新版的艾希已經正式和全世界玩家見面了,很多人都不确定她的未來如何。有些人可能記得,曾經中單艾希是非...
2026-06-03
Copyright 2023-2026 - www.tftnews.com All Rights Reserved