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

Interbase的sql執行錯誤

答題得分者是:st33chen
diyisoft
一般會員


發表:1
回覆:4
積分:1
註冊:2007-09-05

發送簡訊給我
#1 引用回覆 回覆 發表時間:2008-08-11 09:31:05 IP:122.195.xxx.xxx 訂閱
我用ADO+ODBC連接了Interbase 6.5.
但是執行sql的時候老是報錯。
是不是Interbase對sql的要求不同啊。

比如執行查詢語句的時候,必須要在表名上加引號。
select * from "biaoming",
但是在access或是mssql上只要select * from biaoming 就可以了。

是不是interbase對sql語句的要求不一樣啊?

切盼回覆。
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#2 引用回覆 回覆 發表時間:2008-08-11 11:14:57 IP:61.67.xxx.xxx 未訂閱
????? 你在那本書上看到 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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2008-08-12 10:24:27 IP:122.195.xxx.xxx 訂閱
你好啊,我在书上看到的是不用加引号的。
都是select * from tablename.
但是我在实际连接interbase的时候,确实在ADOQuery的sql属性里要用select * from “tablename”才可以的,所以,我才比较纳闷的。
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#4 引用回覆 回覆 發表時間:2008-08-12 13:03:23 IP:122.116.xxx.xxx 訂閱
後學我曾經試用 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

發送簡訊給我
#5 引用回覆 回覆 發表時間:2008-08-13 09:02:24 IP:122.195.xxx.xxx 訂閱
謝謝,我測試一下啊。
diyisoft
一般會員


發表:1
回覆:4
積分:1
註冊:2007-09-05

發送簡訊給我
#6 引用回覆 回覆 發表時間:2008-08-13 15:52:58 IP:122.195.xxx.xxx 訂閱
 依然有問題。
是不是interbase的問題啊?
鬱悶。
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#7 引用回覆 回覆 發表時間:2008-08-15 18:52:12 IP:116.59.xxx.xxx 未訂閱
不管是 Interbase還是 firebird 都沒有加" " 的習慣, 對於你的環境著實令人疑惑!
===================引 用 diyisoft 文 章===================
依然有問題。
是不是interbase的問題啊?
鬱悶。
diyisoft
一般會員


發表:1
回覆:4
積分:1
註冊:2007-09-05

發送簡訊給我
#8 引用回覆 回覆 發表時間:2008-08-16 23:21:41 IP:222.188.xxx.xxx 訂閱
我的是單獨下載的Interbase 6.5,不是delphi7安裝盤里的。

現在根據以上各位的解決方法來測試,還是有問題的,還是需要引號。
但是在delphi里根本沒有辦法寫查詢語句,實在是很難過。

而且在interbase自帶的一個查詢分析器里也要輸入帶引號的表名才能查詢出來結果。

是不是真的是interbase的問題啊?
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#9 引用回覆 回覆 發表時間:2008-09-04 15:11:05 IP:122.116.xxx.xxx 訂閱
今天我用 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

發送簡訊給我
#10 引用回覆 回覆 發表時間:2008-09-04 15:27:12 IP:61.67.xxx.xxx 未訂閱
哦! 原來 INTERBASE還有這層的差別, 以往我都是用 大寫, 所以一直遇不到這樣的問題!
===================引 用 st33chen 文 章===================
今天我用 delphi6 interbase6.0 delphi6 的 interbase 元件 試了一下, 得到結論

1. ibdatabase 元件的 sqldialect 若設為 1
資料庫的 tablename, fieldname 皆需為全大寫否則報錯

... 以下略
系統時間:2024-05-04 10:36:14
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!