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

請教SQL如何去掉最後一個CHAR後作查詢?

答題得分者是:Fishman
huangeider
高階會員


發表:288
回覆:492
積分:231
註冊:2003-02-26

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-04-21 13:38:50 IP:202.145.xxx.xxx 未訂閱
請教紅色部份用+'->'可正常執行 SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO '->')=PRD_NO4.PRD_NO 那若改條件是想除去欄位最後的->改成 SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO-'->')=PRD_NO4.PRD_NO 則無法執行 錯誤如下 Server: Msg 403, Level 16, State 1, Line 2 Invalid operator for data type. Operator equals subtract, type equals varchar. 不知有何方法可以改成 SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO-'->')=PRD_NO4.PRD_NO 像這樣的查詢? 堅持從洗馬桶做起 Eric
huangeider
高階會員


發表:288
回覆:492
積分:231
註冊:2003-02-26

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-04-21 13:57:51 IP:202.145.xxx.xxx 未訂閱
引言: 請教紅色部份用 '->'可正常執行 SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO '->')=PRD_NO4.PRD_NO 那若改條件是想除去欄位最後的->改成 SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO-'->')=PRD_NO4.PRD_NO 則無法執行 錯誤如下 Server: Msg 403, Level 16, State 1, Line 2 Invalid operator for data type. Operator equals subtract, type equals varchar. 不知有何方法可以改成 SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO-'->')=PRD_NO4.PRD_NO 像這樣的查詢? 以下這樣是可以用,但有其他方法嗎? SELECT * FROM TF_BOM,PRD_NO4 WHERE substring(tf_bom.bom_no,1,12)=PRD_NO4.PRD_NO 堅持從洗馬桶做起 Eric
堅持從洗馬桶做起 Eric 發表人 - huangeider 於 2004/04/21 14:40:12
l630521
資深會員


發表:15
回覆:349
積分:372
註冊:2003-02-17

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-04-21 14:00:41 IP:210.66.xxx.xxx 未訂閱
試試看Replace函數 SELECT * FROM TF_BOM,PRD_NO4 WHERE REPLACE(TF_BOM.BOM_NO, '->', '')=PRD_NO4.PRD_NO Ian
Miles
尊榮會員


發表:27
回覆:662
積分:622
註冊:2002-07-12

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-04-21 14:08:07 IP:218.160.xxx.xxx 未訂閱
Hi huangeider 您好:
SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO '->')=PRD_NO4.PRD_NO
這沒問題是因為SQL將它當成單純的字串結合, 所以可過, 但是要將字串移走 請使用l630521兄的方法.
SELECT * FROM TF_BOM,PRD_NO4 WHERE (TF_BOM.BOM_NO-'->')=PRD_NO4.PRD_NO
目前好像沒有這種語法, 我不是高手, 高手是正在銀幕前微笑的人.
------


我不是高手, 高手是正在銀幕前微笑的人.
yachanga
資深會員


發表:24
回覆:335
積分:296
註冊:2003-09-27

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-04-21 14:33:42 IP:210.243.xxx.xxx 未訂閱
Hi huangeider: 假設-> 為最後兩碼 SUBSTRING(TF_BOM.BOM_NO,1,LENGTH(TF_BOM.BOM_NO-2))=B    SUBSTRING 很好用 發表人 -
Fishman
尊榮會員


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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2004-04-21 15:32:43 IP:210.65.xxx.xxx 未訂閱
Sorry !! 插一下花 不知 TF_BOM.BOM_NO 是否 Always 比 PRD_NO4.PRD_NO 多出 '->' 若是,簡單的語法如下即可 < class="code"> SELECT * FROM TF_BOM, PRD_NO4 WHERE TF_BOM.BOM_NO = PRD_NO4.PRD_NO '->' 若不是,則問題就來了 Replace 函數會將 TF_BOM.BOM_NO 中所有 '->' 給置換掉 意即,假設 TF_BOM.BOM_NO = 'ABC->DEF->GHI->',REPLACE('ABC->DEF->GHI->','->','') 會成為 'ABCDEFGHI' 這是否會符合你的需求 因此可能需要,用 >',若是則將會最後兩碼去掉進行判斷 < class="code"> SELECT * FROM TF_BOM, PRD_NO4 WHERE CASE SUBSTRING(TF_BOM.BOM_NO,LEN(TF_BOM.BOM_NO)-1,2) WHEN '->' THEN SUBSTRING(TF_BOM.BOM_NO,1,LEN(TF_BOM.BOM_NO)-2) ELSE TF_BOM.BOM_NO END = PRD_NO4.PRD_NO 發表人 -
------
Fishman
huangeider
高階會員


發表:288
回覆:492
積分:231
註冊:2003-02-26

發送簡訊給我
#7 引用回覆 回覆 發表時間:2004-04-21 16:36:52 IP:202.145.xxx.xxx 未訂閱
這個讚讚 堅持從洗馬桶做起 Eric
系統時間:2024-06-29 16:05:35
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!