Solved

display search results in multiple pages, very urgent (not too difficult)

Posted on 2004-09-21
9
336 Views
Last Modified: 2010-04-01
Hi all, When displaying searched for items I am displaying them in a html table. Id like the search to span into a new page when the amount of items exceeds ten and another page if it exceeds twenty etc etc. Something like how google displays multiple pages for search results. How is this possible?
Thanks.
0
Comment
Question by:SuAeE
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
  • 2
  • +1
9 Comments
 
LVL 6

Expert Comment

by:CodingExperts
ID: 12110479
See if this is of any help....
http://www.codeproject.com/useritems/DBGrid.asp
0
 

Author Comment

by:SuAeE
ID: 12110497

Btw, Im using a mysql database.
0
 
LVL 6

Expert Comment

by:CodingExperts
ID: 12110520
> Im using a mysql database.
Should not be a problem. You can specify the appropriate JDBC driver for MySql in the code.

CodingExpert
0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
LVL 21

Accepted Solution

by:
MogalManic earned 175 total points
ID: 12110647
Just store your query results on the session.  Are you doing the SQL querying within the JSP or are you using a Servlet?

If yours is just a simple application and it is the former then you could do something like this:

PagedQuery.jsp:

< jsp:useBean id="results" "scope="session" class="java.util.List"/>
< jsp:useBean id="pageNum" "scope="session" class="java.lang.Integer"/>
<% if (request.getMethod().equalsIgnoreCase("GET")) {%>
   <jsp:include page="query.jsp"/>
<%}%>
<form name='pagedForm' action='' method='post'/>

<table>
  <%
int rowIdx;
for(rowIdx=pageNum*MAX_ROWS_PER_PAGE;
     rowIdx<results.size() && (rowIdx<(pageNum+1)*MAX_ROWS_PER_PAGE;rowIdx++) {
   ResultsBean eachRow= (ResultsBean)resultsIT.next();
     %><tr><%
     // ... code to display the results
     %></tr><%
}
  %>
<% if (results.size()>MAX_ROWS_PER_PAGE) {%>
<table summary="next_prev Buttons">
  <tr>
      <td>
           <%if ((rowIdx-MAX_ROWS_PER_PAGE)>0) {%>
                   <input type='button' name='Page' value='Prev Page'/>
           <%}%>
      </td>
      <td>
           <%if (rowIdx<size()) {%>
                   <input type='button' name='Page' value='Next Page'/>
           <%}%>
      </td>
  </tr>
</table>
</table>
</form>


query.jsp:
< jsp:useBean id="results" "scope="session" class="java.util.List"/>
<%
//Java code to query DB and move results into 'results' list
...
*>
0
 

Author Comment

by:SuAeE
ID: 12110651

I had a look at that and to be honest it seems too complicated for me :( . And I really cant stand sifting through large amounts of code, much rather write it myself. Any other ideas?
0
 
LVL 35

Assisted Solution

by:TimYates
TimYates earned 175 total points
ID: 12110758
0
 
LVL 21

Expert Comment

by:MogalManic
ID: 12110781
You could also query the database on each page.  Increment/Decrement the pageNumber and post it on the request and when the query is executed, skip the results up until the page requested:
int recNo=0;
while(pageNo*RESULTS_PER_PAGE<recNo) {
   rs.next();  //Skip results in ResultSet before requested page
}

Then process the results up to RESULTS_PER_PAGE.

The pageNumber could be incremented/decremented in a link like this:
<a href="pagedQuery.jsp?pageNo=<%=pageNo+1%>">Next Page</a>
<a href="pagedQuery.jsp?pageNo=<%=pageNo-1%>">Previous Page</a>
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Compliance and data security require steps be taken to prevent unauthorized users from copying data.  Here's one method to prevent data theft via USB drives (and writable optical media).
The recent Petya-like ransomware attack served a big blow to hundreds of banks, corporations and government offices The Acronis blog takes a closer look at this damaging worm to see what’s behind it – and offers up tips on how you can safeguard your…
Monitoring a network: how to monitor network services and why? Michael Kulchisky, MCSE, MCSA, MCP, VTSP, VSP, CCSP outlines the philosophy behind service monitoring and why a handshake validation is critical in network monitoring. Software utilized …
If you’ve ever visited a web page and noticed a cool font that you really liked the look of, but couldn’t figure out which font it was so that you could use it for your own work, then this video is for you! In this Micro Tutorial, you'll learn yo…

628 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question