T-SQL查詢access的資料表名的列表

來源:互聯網
上載者:User
  1. select name
  2. from
  3. OpenRowSet('microsoft.jet.oledb.4.0',';database=c:/db1.mdb','select * from MSysObjects') 

     今天開啟CSDN發一個網友問我如何用T-SQL判斷某個表在ACCESS中是否存在,也就是如何用t-sql顯示access的使用者表,其實access有一個隱藏了類似於sysobjects的系統資料表,並且必須設定許可權才可以訪問得到,下面我寫出我測試的過程:

 

    環境:SQL SERVER 2005,ACCESS2000

 

    首先,我們讓類似於MSSQL的幾個系統資料表顯示出來,點擊工具->選項->視圖->系統對象前面打上勾,點確定,你會發現在對象->表下面多出5個MS打頭的表,這是就隱藏的系統資料表。

    接著,我們如果在查詢分析器中運行:

 

 

報錯如下:

訊息 7357,層級 16,狀態 2,第 1 行
無法處理對象 "select * from MSysObjects"。連結的伺服器 "(null)" 的 OLE DB 提供者 "microsoft.jet.oledb.4.0" 指示該對象沒有列,或目前使用者沒有訪問該對象的許可權。

    其實這是因為沒有許可權的原因造成的,那麼我們開啟這個操作許可權,工具->安全->使用者與組安全->選表msysobjects,設定許可權,點確定後再運行上面的語句看看,

 

select name
from
OpenRowSet('microsoft.jet.oledb.4.0',';database=c:/db1.mdb','select * from MSysObjects')
where type = 1 and flags = 0
/*
name
------------------------------------------------------------------------------------------

ta
Switchboard Items
myclass
ta1
ta2

(5 行受影響)

*/
註:以上我測試的ACCESS內的使用者表。

 

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.