Interbase的sql執行錯誤 |
答題得分者是:st33chen
|
diyisoft
一般會員 發表:1 回覆:4 積分:1 註冊:2007-09-05 發送簡訊給我 |
|
P.D.
版主 發表:603 回覆:4038 積分:3874 註冊:2006-10-31 發送簡訊給我 |
????? 你在那本書上看到 select * from "biaoming"的用法啊? 怎麼我從來不知道呢!
===================引 用 diyisoft 文 章=================== 我用ADO ODBC連接了Interbase 6.5. 但是執行sql的時候老是報錯。 是不是Interbase對sql的要求不同啊。 比如執行查詢語句的時候,必須要在表名上加引號。 select * from "biaoming", 但是在access或是mssql上只要select * from biaoming 就可以了。 是不是interbase對sql語句的要求不一樣啊? 切盼回覆。 |
diyisoft
一般會員 發表:1 回覆:4 積分:1 註冊:2007-09-05 發送簡訊給我 |
|
st33chen
尊榮會員 發表:15 回覆:591 積分:1201 註冊:2005-09-30 發送簡訊給我 |
後學我曾經試用 interbase,
發現, 如果在 create 欄位時用英文小寫, 以後的 sql statements 要用引號, 反之, 如果 用英文大寫的欄位名, 就可以不用引號. 但我的經驗是 欄位, 不知是否一樣 apply 到 tablename, 參考一下. thanks ===================引 用 diyisoft 文 章=================== 我用ADO ODBC連接了Interbase 6.5. 但是執行sql的時候老是報錯。 是不是Interbase對sql的要求不同啊。 比如執行查詢語句的時候,必須要在表名上加引號。 select * from "biaoming", 但是在access或是mssql上只要select * from biaoming 就可以了。 是不是interbase對sql語句的要求不一樣啊? 切盼回覆。
------
IS IT WHAT IT IS 我是 李慕白 請倒著唸. 又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦); 都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲. |
diyisoft
一般會員 發表:1 回覆:4 積分:1 註冊:2007-09-05 發送簡訊給我 |
|
diyisoft
一般會員 發表:1 回覆:4 積分:1 註冊:2007-09-05 發送簡訊給我 |
|
P.D.
版主 發表:603 回覆:4038 積分:3874 註冊:2006-10-31 發送簡訊給我 |
|
diyisoft
一般會員 發表:1 回覆:4 積分:1 註冊:2007-09-05 發送簡訊給我 |
|
st33chen
尊榮會員 發表:15 回覆:591 積分:1201 註冊:2005-09-30 發送簡訊給我 |
今天我用 delphi6 + interbase6.0 + delphi6 的 interbase 元件 試了一下, 得到結論
1. ibdatabase 元件的 sqldialect 若設為 1 資料庫的 tablename, fieldname 皆需為全大寫否則報錯 select * from fsk001 會解釋為 select * from FSK001, 但 資料庫中有 fsk001 無 FSK001 故報錯(找不到 table) select * from "fsk001" 無法解釋, 因為認為句中不應有 " 出現. 2. ibdatabase 元件的 sqldialect 若設為 3 資料庫的 tablename, fieldname 若有小寫要用雙引號括起來 select * from fsk001 會解釋為 select * from FSK001, 但 資料庫中有 fsk001 無 FSK001 故報錯(找不到 table) select * from "fsk001" 沒問題 建議: 不想在 sql statements 中打雙引號, 請在 create table 時, tablename, fieldname 設為全大寫(每個字都是大寫), 那麼不管 sqldialect 是1還是3 select * from fsk001 select * from FSK001 都是 OK 的, (我想, 連 select * from Fsk001 或 fSK001,... 也是 OK 的) 參考一下 如果還不行, 請說明您是如何試的? 您要重新建立 TABLE 而且 表格名, 欄位名都要取全大寫的的名稱
------
IS IT WHAT IT IS 我是 李慕白 請倒著唸. 又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦); 都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲.
編輯記錄
st33chen 重新編輯於 2008-09-04 15:18:29, 註解 無‧
|
P.D.
版主 發表:603 回覆:4038 積分:3874 註冊:2006-10-31 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |