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

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

ただいまの
回答率

90.11%

JavaEEでユーザ入力によるデータテーブルの検索をするには

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 731

anonyrabbit

score 60

primefacesでデータベースの内容をデータテーブルにして表示しているところまで来ているのですが、そのデータテーブルの中身を検索する機能の実装ができなくて困っています。

    public List<OldCoupleInformation> filterTable(String inputAddressOne) {
        return em.createQuery("SELECT c FROM OldCoupleInformation c WHERE c.addressOne = :inputAddressOne ").getResultList();

    }

上記のメソッドを

    public List<OldCoupleInformation> findByAddress(String search) {
        return db.filterTable(search);
    }

のようにして使おうと思っています。引数のString searchはユーザ入力で、xhtml側は以下のようになっています。

   <p:inputText id="globalFilter" value="#{cb.search}" style="width:150px" placeholder="Enter keyword"/>
   <h:commandButton action="#{cb.findByAddress(cb.search)}" class="Button"/>


 <p:dataTable id="examplej" class="table table-striped table-bordered dt-responsive nowrap table-hover" 
                         var="info" value="#{bb.coupleList}" rows="10" paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
                         rowsPerPageTemplate="5,10,15" paginator="true" emptyMessage="お探しの地域では見つかりませんでした">
                <f:facet name="header">
                    <p:outputPanel>
                        <h:outputText value="Search all fields:" />
                    </p:outputPanel>

                </f:facet>

                <p:column>
                    <p:graphicImage value="#{bb.pic}" >
                        <f:param name="id" value="#{info.id}"/>
                    </p:graphicImage>
                </p:column>

                <p:column>
                    <h:outputText value="#{info.addressOne}" />
                </p:column>


                <p:column>
                    <h:outputText value="#{info.firstName}" />さん
                </p:column>



                <p:column>
                    <h:commandLink action="#{bb.detail(info)}">
                        詳細へ
                    </h:commandLink>  
                </p:column>


            </p:dataTable>

しかしこのボタンを押しても何も起こらず困っています。おそらくListをデータテーブルへと再表示するのがうまくいっていないのだと思いますがどうすればいいかお分かりになるかた回答の方よろしくお願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • BlueMoon

    2016/12/30 10:10

    <h:form>タグは付いていますか? JSFとBackingBeanの紐づけができていないとエラーも何も表示されない場合が有ります。package定義やscopeアノテーションを見直した方が良いかも知れません。

    キャンセル

  • anonyrabbit

    2016/12/31 00:11

    formタグはついています。package定義やscopeアノテーションも確認しました。Query文は合っていますでしょうか?

    キャンセル

回答 1

checkベストアンサー

+1

「ボタンを押して何も起こらない」という状況から、BackingBean(cb.findByAddress)の呼び出しが成功していないように思えます。まずはその点を解決する方向で調査されてはどうでしょうか。以下は思い付く手法です。

  • メソッドの適所にログ出力を入れる
  • クリーンコンパイルしてみる
  • アンデプロイ、デプロイをやり直してみる

Queryが正しいか確認するにはDataBase情報、Table構成の情報が必要ですが、開示頂いたとしても机上での確認は難しいです。多分、Queryが間違っていれば画面、またはログにエラー情報が出力されると思います。ご参考までに。

<h:form>タグで間違えないでしょうか。<form>タグだと動作しないかも知れません。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/01/01 19:57

    関連する質問を投稿しましたのでもしよろしければご回答いただけると助かります。

    キャンセル

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

  • ただいまの回答率 90.11%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる