線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1212
推到 Plurk!
推到 Facebook!

如何用sql語法得知某db的資料結構?

尚未結案
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-01-08 18:05:17 IP:210.61.xxx.xxx 未訂閱
參考http://delphi.ktop.com.tw/topic.php?topic_id=39000 一文 select cast(COLUMN_NAME as varchar(20)) 欄位名稱, cast(DATA_TYPE as varchar(10)) 欄位類型, cast(CHARACTER_MAXIMUM_LENGTH as varchar(6)) 長度, cast(COLUMN_DEFAULT as varchar(10)) 預設值,IS_NULLABLE 允許空值 from INFORMATION_SCHEMA.COLUMNS where TABLE_NAME = ''YourTableName'''; 但我在SQL Query Analyzer試了一下 並未回傳正確的值 請問這語法是對的麼? 還是有其它的語法? 請大家幫忙, 謝謝各位. ps: sql2000
James
高階會員


發表:10
回覆:290
積分:220
註冊:2002-07-25

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-01-08 18:28:26 IP:61.218.xxx.xxx 未訂閱
測試一下, 感覺沒有什麼問題, 抓到的也是正確的, 我是拿 pubs 裡面 Table 來測試,你能詳細說明一下 是哪裡有問題嘛 ?
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-01-12 11:41:49 IP:210.61.xxx.xxx 未訂閱
James兄 小弟用上面的語法在query analyzer依然返回的是 (0 row(s) affected) 照道理應該list出pubs裡的schema才對 而不是空空如也 我想是不是上面語法有誤 還是我那個地方弄錯了?
terrychen
尊榮會員


發表:90
回覆:794
積分:501
註冊:2003-05-01

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-01-12 11:51:54 IP:61.221.xxx.xxx 未訂閱
您好pedro: 剛剛小弟也試了一下,語法沒問題阿 可以正常執行及得出結果 會不會是資料庫的問題 ~~應無所住而生其心~~ 發表人 - Terrychen 於 2004/01/12 11:57:26
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-01-12 13:03:22 IP:210.61.xxx.xxx 未訂閱
資料庫應是正常的 其它的sql statement都可以正常work 而且server是新安裝的 況且大家的結果都是正常 但唯獨這個 這令人百思不得其解.......
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#6 引用回覆 回覆 發表時間:2004-01-12 15:13:41 IP:210.65.xxx.xxx 未訂閱
Hi:    pedro,請 Check 資料庫中是否確實有 pubs 此 Table,新安裝之 Server pubs 應該是資料庫,而非實體 Table,有可能是你所指定之 Table_Name 並不存在 -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#7 引用回覆 回覆 發表時間:2004-01-12 15:24:09 IP:210.61.xxx.xxx 未訂閱
行了 感謝Fishman兄 小弟一時不查 把tablename誤認為dbasename 所以一直試不出來 結果如Fishman兄所言 對應正確的tablename返回清單就出來了
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#8 引用回覆 回覆 發表時間:2004-01-12 15:27:54 IP:210.61.xxx.xxx 未訂閱
但是這要逐table列出schema 有沒有比較smart的方式 可以列出一整個db content?
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#9 引用回覆 回覆 發表時間:2004-01-12 15:47:30 IP:210.65.xxx.xxx 未訂閱
Hi:    你可以去 Select sysobjects 這個 Table,裡面會列出該 DataBase 中所有的 Objects,當然也包括 Table_Name,再與你之前的語法 Join 起來,應該就可以了,試試看 -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#10 引用回覆 回覆 發表時間:2004-01-12 16:19:00 IP:210.61.xxx.xxx 未訂閱
謝謝Fishman兄的提示 我會去try 謝謝各位前輩的幫忙 發表人 - pedro 於 2004/01/12 16:27:45
系統時間:2024-05-19 11:57:01
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!