質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

1回答

1350閲覧

動的に指定した値を入れる処理

EDM

総合スコア30

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2020/11/19 08:32

編集2020/11/20 04:37

画面にフォームの受信日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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

EDM

2020/11/20 04:35

戻しときます
guest

回答1

0

自己解決

自己解決しました。削除リクエスト却下されました。

投稿2020/11/20 02:50

EDM

総合スコア30

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問