画面にフォームの受信日From,受信日Toというテキストボックスがあります。
両方日付を入力してsubmitし、色々介しながら入力内容をバインドし、SQLにてbetween :uketsukebiFrom AND :uketsukebiTo をすることにより、入力した範囲のデータをデータベースから出力することができています。
そこで次の工程として、Fromには入力、Toには未入力の場合、プログラムで指定した値が自動的にtoに入り、その範囲内のデータを表示させたい。それぞれが独立したテキストボックスとして利用したい。逆もしかり。
例として
受信日From ”2000-1-1” 受信日To "未入力" でsubmitすると自動的に未入力に本日の日付が入りその範囲のデータを出力。
受信日From "未入力" 受信日To "2020-12-31" でsubmitすると自動的に未入力に"2000-1-1"が入りその範囲のデータを出力。
もちろん通常通り二つとも入力した場合もその範囲のデータを出力
その自動的に指定した値を入れる処理についてequalsを使用した処理を書きたいのですがどのように書けばいいのかわかりません。
equalsの書き方はcheckboxの時にやったことはありますがそれとは違うためよく理解できていません。
Serviceのtry-catchの部分です。
SQLも今のままでいいのか orで 区切っていくのか
例えば
(between :uketsukebiFrom AND :uketsukebiTo)or (between :uketsukebiFrom1 AND :uketsukebiTo)みたいに自動的に入った場合はバインドの名前を変えるようにするみたいな。
ちなみにデータベースにある受信日はDate型、テキストに入力する際はString型だがその変換はできている。java.sql.Dateのところ。
コードは本当に必要なところだけ抜粋しています。
search
1<form:form modelAttribute="SearchBean" 2 action="Search_search.htm" method="POST"> 3 <table border="1"> 4 <tr> 5 <th rowspan="2">受付日</th> 6 <th>(from)</th> 7 <td><input type="text" name="From"></td> 8 </tr> 9 <tr> 10 <th>(to)</th> 11 <td><input type="text" name="To"></td> 12 </tr> 13 </table> 14 <input type="submit" name="search"value="検索"> 15 </form:form> 16 <c:forEach var="row" items="${ResultBean.list}"> 17 <tr> 18 <td>${row.uketsukebi}</td> 19 </tr> 20 </c:forEach>
controller
1//Search.jspにてsubmit(検索)がクリックされた時 2@RequestMapping(value="Search_search",method=RequestMethod.POST) 3 public ModelAndView Search_search(@ModelAttribute("searchBean") SearchBean searchBean) 4 { 5 ResultBean result = Service.selectService(searchBean); 6 ModelAndView mv = new ModelAndView("search"); 7 mv.addObject("searchBean",searchBean); 8 mv.addObject("resultBean",result); 9 return mv; 10 }
SearchBean
1protected String from; 2protected String to;
ResultBean.java
1protected int count ; 2protected List<SearchDto> list;
Service
1public ResultBean selectService(SearchBean searchBean) 2 { 3 try 4 { 5 //ここの部分です。 6 **if(searchBean.from =.equals(searchBean.getFrom(null))) 7 { 8 searchBean.From() = "2000-1-1"; //入力するときはまだStringのはず 9 } 10 if(searchBean.to =.equals(searchBean.getTo(null))) 11 { 12 searchBean.From() = "2020-12-31"; 13 }** 14 java.sql.Date FROM = java.sql.Date.valueOf(searchBean.getFrom()); 15 java.sql.Date TO = java.sql.Date.valueOf(searchBean.getTo()); 16 17 List<SearchDto> list = searchDao.select(FROM,TO); 18 return new ResultBean(list.size(),list); 19 } 20 catch (Exception e) 21 { 22 e.printStackTrace(); 23 return new ResultBean 24 (-1,null); 25 } 26 }
SearchDto
1protected Date uketsukebi;
SearchDao
1public List<SearchDto> select(java.sql.Date FROM,java.sql.Date TO) 2 { 3 String sql = properties.getProperty 4 ("jdbc.sql.select"); 5 RowMapper rm = new BeanPropertyRowMapper<SearchDto> 6 (SearchDto.class); 7 MapSqlParameterSource namedParam = 8 new MapSqlParameterSource(); 9 namedParam.addValue("uketsukebiFrom",FROM,Types.DATE); 10 namedParam.addValue("uketsukebiTo",TO,Types.DATE); 11 return getNamedParameterJdbcTemplate().query 12 (sql,namedParam,rm); 13 }
properties
1jdbc.sql.select=select UKETSUKEBI from CUSTOMER where UKETSUKEBI BETWEEN :uketsukebiFrom AND :uketsukebiTo
回答1件
あなたの回答
tips
プレビュー