作者BILL0119 (BILL)
看板Web_Design
標題Re: [問題] JSP比較資料庫檔案時間與系統時間
時間Sat May 9 23:35:17 2009
※ 引述《BILL0119 (BILL)》之銘言:
: 標題: Re: [問題] JSP比較資料庫檔案時間與系統時間
: 時間: Sat May 9 01:51:29 2009
:
: ※ 引述《BILL0119 (BILL)》之銘言:
: : 標題: [問題] JSP比較資料庫檔案時間與系統時間
: : 時間: Thu May 7 14:00:15 2009
: :
: : 目前有個JSP的問題想請板上的高手解答
: :
: : 我想抓出資料庫內的時間
: :
: : 並且比較目前系統時間 (只需要比較年份)
: :
: : 例如目前時間是2009年,資料庫內的時間是2003-7-20
: :
: : 我想要列出2003,2004,2005,2006,2007,2008,2009
: :
: : 但是資料庫內的時間格式是 年-月-日
: :
: : 目前時間
: : Calendar thisMonth=Calendar.getInstance();
: : String year=String.valueOf(thisMonth.get(Calendar.YEAR));
: :
: :
: : 資料庫內的時間
: : java.sql.Date dt = rs.getDate("DATE");
: : SimpleDateFormat sFmt = new SimpleDateFormat("yyyy");
: : String sDt = sFmt.format(dt);
: :
: :
: : 我要怎麼比較現在的系統時間
: :
: : 謝謝
: :
: :
: : --
: : ※ 發信站: 批踢踢實業坊(ptt.cc)
: : ◆ From: 114.42.160.15
: : ※ 編輯: BILL0119 來自: 114.42.160.15 (05/07 14:04)
: : ※ 編輯: BILL0119 來自: 114.42.160.15 (05/07 14:21)
: : 推 pm2001:從資料庫拉資料出來不然就下sql指令給資料庫算 05/07 14:24
:
: 不好意思,我是新手
: 想再請教一下,我下了SQL給資料庫運算後,要怎麼取運算後的數值啊??
: 假設說我下了 select count(no) as count from db.pt_info
: where year(current timestamp) - year(birthday) <35
: and sex IN('F')
: 想要取得小於35歲女性的人數
: 我看網路的資料都是用
: Connection conn = java.sql.DriverManager.getConnection
: (url,user,password);
:
: Statement stmt=conn.createStatement
: (ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
:
: ResultSet rs = stmt.executeQuery("select count(no) ...........");
: 這表示他會回傳人數int給 ResultSet rs嗎? (但是這樣會有error訊息)
:
:
:
: : → GALINE:都是四位數年份字串的話....sdt.equals(year) ? 05/07 14:28
: : → GALINE:我自己是偏好資料庫內把時間存成字串,然後用substr做比對 05/07 14:29
: : → BILL0119:資料型態都是String,要怎麼運算呢? 05/07 15:25
: : 推 GALINE:用Integer.parseInt轉成數字再來算。不過最主要的原因是我 05/07 15:44
: : → GALINE:用不習慣原生的日期型態…[汗] 05/07 15:45
: : → TonyQ:其實可以直接下 year 給sql 去撈字串啊... 05/07 15:52
: : → BILL0119:了解,謝謝各位高手 05/07 16:03
:
: --
: ※ 發信站: 批踢踢實業坊(ptt.cc)
: ◆ From: 114.42.161.22
: 推 TonyQ: as count count是保留字 , 寫成 as [count] or 換個名字 05/09 09:06
: → BILL0119:我直接在資料庫下這些指令是ok的,但是從JSP丟過去就錯了 05/09 11:26
: → BILL0119:指向 ResultSet rs = stmt.executeQuery(SQL) 有問題 05/09 11:28
: → BILL0119:但是我換成較簡單的指令都可以過 05/09 11:28
: → BILL0119:例如:select test from db2admin.test_data 05/09 11:29
: → BILL0119:真是讓我百思不得其解 =.= 05/09 11:30
: 推 GALINE:錯誤訊息是?單純數筆數我會用count(*) 05/09 13:27
: → TonyQ:那就把error message 拿出來看看. 05/09 18:31
訊息指出
HTTP Status 500
type Exception report
message
description The server encountered an internal error ()
that prevented it from fulfilling this request.
exception
org.apache.jasper.JasperException:
Exception in JSP: /Pages/AA_SQL_TEST.jsp:65
62:
63:
64: String sql = "select count(*) as count from db2admin.pt_info
where year(current timestamp) - year(birthday) <35 and sex IN('F')";
65: ResultSet rs = stmt.executeQuery(sql);
66:
67:
68:
這表示65行有問題?
這個SQL指令我在資料庫指令列下是ok的
我的環境是用apache-tomcat-5.5.27
eclipse java6-u13
db2資料庫
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 114.42.80.235
→ TonyQ:這訊息沒有幫助 , 去查tomcat log ,找出這internal error 05/09 23:38
→ TonyQ:的detail來看才有幫助. 05/09 23:38
推 etchen:應該是65行在執行sql指令的時候有問題...把sql指令改一下吧 05/10 12:18
→ etchen:Select count(*) as countinfo from pt_info 05/10 12:19
→ etchen:where (year(current timestamp) - year(birthday)) <35 05/10 12:20
→ etchen:and sex IN('F') 05/10 12:20
→ etchen:as什麼東西盡量不要用保留字,還有算年時加上括弧 05/10 12:21
→ etchen:最好把sql指令用print out出來再到資料庫QUERY下看看 05/10 12:22
→ etchen:有沒有問題。 05/10 12:22
→ BILL0119:我發現去掉COUNT指令就可以執行,這表示不能計數嗎? 05/10 14:34
→ BILL0119:有其他辦法可以計數嗎?? 05/10 14:34
→ TonyQ:如果在 dbms 上可以執行的查詢 , 搬到 jsp 就一定可以. 05/10 14:49
→ TonyQ:你去翻 tomcat log 先啦 , 有 log 不找瞎猜幹麼...-_- 05/10 14:49
→ TonyQ:通常會在tomcat根目錄的 logs資料夾下 05/10 14:50
→ andymai:樓上~我同事也很愛幹這種事情~有時真不懂他們在堅持什麼.. 05/10 21:45