全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:2528
推到 Plurk!
推到 Facebook!

SQL command 的問題

尚未結案
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#1 引用回覆 回覆 發表時間:2002-08-29 13:42:30 IP:203.74.xxx.xxx 未訂閱
以下是我的 sql 指令 但執行時出現無效的 sql 陳述式, 預期為 delete, insert, procedure, select 或 update 請問我這樣的語法有錯誤嗎 ? sqlCommand := 'select SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num'; sqlCommand := ' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date'; Query2.SQL.Clear; Query2.SQL.Add(sqlCommand); Query2.ParamByName('num1').AsDateTime := t1; Query2.ParamByName('num2').AsDateTime := t2; Query2.Open;
andersonhsieh
版主


發表:33
回覆:531
積分:439
註冊:2002-06-10

發送簡訊給我
#2 引用回覆 回覆 發表時間:2002-08-29 13:50:15 IP:211.20.xxx.xxx 未訂閱
sqlCommand := 'select SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num'; sqlCommand := ' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date';這一行錯了應為sqlCommand := sqlCommand ' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date'; Query2.SQL.Clear; Query2.SQL.Add(sqlCommand); Query2.ParamByName('num1').AsDateTime := t1; Query2.ParamByName('num2').AsDateTime := t2; Query2.Open; @@~~飛翔在天際的精靈~~@@
------
@@~~飛翔在天際的精靈~~@@
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#3 引用回覆 回覆 發表時間:2002-08-29 14:24:01 IP:203.74.xxx.xxx 未訂閱
我己將其改成 sqlCommand := 'select SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num'; sqlCommand := sqlCommand ' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date'; 但執行時仍出現 您企圖執行一個查詢不包含做為總合函數的一部分的指定運算式 'Sales_num' 請問這是什麼地方的問題呢 ? thanks!
andersonhsieh
版主


發表:33
回覆:531
積分:439
註冊:2002-06-10

發送簡訊給我
#4 引用回覆 回覆 發表時間:2002-08-29 14:32:50 IP:211.20.xxx.xxx 未訂閱
你的資料庫為何,連接資料庫方式為何bde,odbc,或ado? @@~~飛翔在天際的精靈~~@@
------
@@~~飛翔在天際的精靈~~@@
fanny
一般會員


發表:10
回覆:26
積分:7
註冊:2002-07-19

發送簡訊給我
#5 引用回覆 回覆 發表時間:2002-08-29 14:37:27 IP:61.222.xxx.xxx 未訂閱
引言: 我己將其改成 sqlCommand := 'select SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num'; sqlCommand := sqlCommand ' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date'; 但執行時仍出現 您企圖執行一個查詢不包含做為總合函數的一部分的指定運算式 'Sales_num' 請問這是什麼地方的問題呢 ? thanks! 若改成 sqlCommand := 'select distinct SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num'; sqlCommand := sqlCommand ' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date'; 試試看,因為sum()函數是一個總合函數,前面所選的欄位必須是唯一性,否則會造成多對一的錯誤,所以除了用distinct也可以試著每一個欄位加上max()或者min()試試看。
andersonhsieh
版主


發表:33
回覆:531
積分:439
註冊:2002-06-10

發送簡訊給我
#6 引用回覆 回覆 發表時間:2002-08-29 14:42:04 IP:211.20.xxx.xxx 未訂閱
加上 group by SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num 試試看 @@~~飛翔在天際的精靈~~@@
------
@@~~飛翔在天際的精靈~~@@
crlin
一般會員


發表:47
回覆:57
積分:20
註冊:2002-07-23

發送簡訊給我
#7 引用回覆 回覆 發表時間:2002-08-30 15:19:45 IP:203.74.xxx.xxx 未訂閱
我己將 SQL 語法改成 Query2.SQL.Add('select SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT group by SA_BS.Sales_num where SA_DT.Sales_num = SA_BS.Sales_num'); Query2.SQL.Add(' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date'); 執行時仍有錯誤訊息 查詢運算式 SA_BS.Sales_num where SA_DT.Sales_num = SA_BS.Sales_num and SA_BS.SA_date >= ? and SA_BS.SA_date < ? 中的語法錯誤(少了運算元) 請問是少了什麼運算元呢 ?
andersonhsieh
版主


發表:33
回覆:531
積分:439
註冊:2002-06-10

發送簡訊給我
#8 引用回覆 回覆 發表時間:2002-08-30 16:10:00 IP:211.20.xxx.xxx 未訂閱
正確的sql應該是    select SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 order by SA_BS.SA_date group by SA_BS.Sales_num, SA_BS.SA_date, SA_BS.Bill_num, SA_BS.ticket_num @@~~飛翔在天際的精靈~~@@ 發表人 - andersonhsieh 於 2002/08/30 16:53:17
------
@@~~飛翔在天際的精靈~~@@
fanny
一般會員


發表:10
回覆:26
積分:7
註冊:2002-07-19

發送簡訊給我
#9 引用回覆 回覆 發表時間:2002-08-30 16:45:32 IP:61.222.xxx.xxx 未訂閱
引言: 若改改成 Query2.SQL.Add('select SA_BS.Sales_num,SA_BS.SA_date,SA_BS.Bill_num, SA_BS.ticket_num, sum(SA_DT.Sell_Penny) as f1 from SA_BS, SA_DT where SA_DT.Sales_num = SA_BS.Sales_num'); Query2.SQL.Add(' and SA_BS.SA_date >= :num1 and SA_BS.SA_date < :num2 group by SA_BS.Sales_num,SA_BS.SA_date,SA_BS.Bill_num, SA_BS.ticket_num order by SA_BS.SA_date'); 試試看。
系統時間:2024-05-05 9:24:22
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!