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

如何用update 程序 replcae 分數成績?

尚未結案
yesman
一般會員


發表:5
回覆:6
積分:2
註冊:2005-06-20

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-06-20 11:01:34 IP:24.42.xxx.xxx 未訂閱
請問大家update command 的運用  本人有 table : Grades column : grade 想將 grade column 內的分數 如分數>82 or = 82 轉為 A    Letter Grade        Numeric Grade          A        82          B        77          C        62          D        51          F        45    我嘗試用以下command , 雖然沒有error, 但也沒有任何轉變 >update grades set grade= 'A'  ->where grade = '>82 or =82';    請問如何才可以把分數轉為 grade 呢?    謝謝< src="http://delphi.ktop.com.tw/loadfile.php?TOPICID=23020850&CC=514850">
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-06-20 11:10:51 IP:61.70.xxx.xxx 未訂閱
您好: 您的下法有問題,改成以下這樣 update grades set grade= 'A' where grade >= '82'
yesman
一般會員


發表:5
回覆:6
積分:2
註冊:2005-06-20

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-06-20 11:23:27 IP:24.42.xxx.xxx 未訂閱
謝謝 supman 語法沒問題了.. 但另一個問題也發生.. 在 column grade 內原內容為    grade    -->   grade -----          -----  B               A  C               A 45              45  78              78 82               A    B-->A C-->A    那原因在那裡呢? 如何解決呢?    另一問題是 如果 B =>77 and <82 >update grades set grade='B' where grade>='77' and <'82'; 那就有問題了.. 多謝相謝~~! 發表人 -
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-06-20 11:32:57 IP:61.70.xxx.xxx 未訂閱
您好: 再多設一個終值. update grades set grade= 'A' where grade >= '82' and grade<='99'
pgdennis
資深會員


發表:41
回覆:526
積分:443
註冊:2002-05-23

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-06-20 11:34:12 IP:218.163.xxx.xxx 未訂閱
因為你用'B'與'82'判斷的話,資料庫會把'B'轉成ASCII Code, 要避免可以先將'B'轉成'BXX'等字串,之後再轉回來, 或在where條件中加入is_numeric()判斷該field值是否為數字(我不確定Mysql有無此func) < >< >< >< > 星期一,星期二...星期日..星期一..無窮迴圈@@
------
星期一,二...無窮迴圈@@
yesman
一般會員


發表:5
回覆:6
積分:2
註冊:2005-06-20

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-06-20 12:09:50 IP:24.42.xxx.xxx 未訂閱
引言: 因為你用'B'與'82'判斷的話,資料庫會把'B'轉成ASCII Code, 要避免可以先將'B'轉成'BXX'等字串,之後再轉回來, 或在where條件中加入is_numeric()判斷該field值是否為數字(我不確定Mysql有無此func) < >< >< >< > 星期一,星期二...星期日..星期一..無窮迴圈@@ < face="Verdana, Arial, Helvetica"> 那請問如果本身那個column 有 A 那個英文字就不可以被免把打改變嗎?
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-06-20 12:18:19 IP:61.70.xxx.xxx 未訂閱
您好: 看不董您紅色那段的意思. 那請問如果本身那個column 有 A 那個英文字就不可以被免把打改變嗎? 為何要設定終值是因為,您的分數是一個字串型態,在字串排列上,A,B,C...是大於0,1,2...的因此如果只設定where grade>'82',則原本A,B,C...也會符合該條件,因此也會一併被改掉資料.
yesman
一般會員


發表:5
回覆:6
積分:2
註冊:2005-06-20

發送簡訊給我
#8 引用回覆 回覆 發表時間:2005-06-20 12:47:18 IP:24.42.xxx.xxx 未訂閱
明白.. 但如何做法呢?     發表人 - yesman 於 2005/06/20 12:52:15
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#9 引用回覆 回覆 發表時間:2005-06-20 12:55:33 IP:61.70.xxx.xxx 未訂閱
如何做?????做什麼??? 上面不是已經寫了    >再多設一個終值. >update grades set grade= 'A' where grade >= '82' and grade<='99'    看不董您紅色那段的意思. 那請問如果本身那個column 有 A 那個英文字就不可以被免把打改變嗎?
yesman
一般會員


發表:5
回覆:6
積分:2
註冊:2005-06-20

發送簡訊給我
#10 引用回覆 回覆 發表時間:2005-06-20 14:35:51 IP:24.42.xxx.xxx 未訂閱
引言: 看不董您紅色那段的意思. 那請問如果本身那個column 有 A 那個英文字就不可以被免把打改變嗎?
首先多謝各位的幫忙 我的意思是我本身的 column Course Grade ------- ---- HWD101 B OPS440 C 但正如pgdennis 所說 當我第一次輸入 update grades set grade= 'A' where grade >= '82' 之後不單只所有 >= 82 轉為 A 連最初的 HWD101 & OPS440 的 grade 也轉為 A 所有沒有方法忽略 最初是英文字的value 然後把之後的數字 轉為指定數值(A)
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#11 引用回覆 回覆 發表時間:2005-06-20 16:40:02 IP:61.70.xxx.xxx 未訂閱
這是我第三次貼上以下這段 update grades set grade= 'A' where grade >= '82' and grade<='99' 請您把回文看清楚,設定grade大於82且必須小於99就是要去忽略原本欄位裡就已經是A,B,C...的資料. 如果還有問題,請舉出上面那段SQL哪邊是有問題的????
系統時間:2024-06-28 19:34:43
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!