zoukankan      html  css  js  c++  java
  • Goods:图书模块按分类查询各层实现

    BookDao

      1  //按分类查询
      2       public PageBean<Book>  findByCategory(String cid,int pc) throws SQLException
      3       {
      4           List<Expression> exprList=new ArrayList<Expression>();
      5           exprList.add(new Expression("cid", "=", cid));
      6           return findByCriteria(exprList, pc);
      7           
      8       }
      9       
     10       //按书名做一个模糊查询
     11       public PageBean<Book>  findByBname(String bname,int pc) throws SQLException
     12       {
     13           List<Expression> exprList=new ArrayList<Expression>();
     14           exprList.add(new Expression("bname", "like", "%"+bname+"%"));
     15           return findByCriteria(exprList, pc);
     16           
     17       }
     18       
     19       //按作者查询
     20       public PageBean<Book>  findByAuthor(String author,int pc) throws SQLException
     21       {
     22           List<Expression> exprList=new ArrayList<Expression>();
     23           exprList.add(new Expression("author", "like", "%"+author+"%"));
     24           return findByCriteria(exprList, pc);
     25           
     26       }
     27       
     28       
     29       //按出版社查询
     30       public PageBean<Book>  findByPress(String press,int pc) throws SQLException
     31       {
     32           List<Expression> exprList=new ArrayList<Expression>();
     33           exprList.add(new Expression("press", "like", "%"+press+"%"));
     34           return findByCriteria(exprList, pc);
     35           
     36       }
     37       //多条件组合查询  book对象本身就是条件
     38       public PageBean<Book>  findByCombination(Book criteria,int pc) throws SQLException
     39       {
     40           List<Expression> exprList=new ArrayList<Expression>();
     41           exprList.add(new Expression("bname", "like", "%"+criteria.getBname()+"%"));
     42           exprList.add(new Expression("author", "like", "%"+criteria.getAuthor()+"%"));
     43           exprList.add(new Expression("press", "like", "%"+criteria.getPress()+"%"));
     44           return findByCriteria(exprList, pc);
     45           
     46       }
     47       
     48       //
     49       
     50       /*
     51        * 通用的查询方法
     52        */
     53       private PageBean<Book> findByCriteria(List<Expression> exprList,int pc) throws SQLException
     54       {  
     55           /*
     56            * 1、得到ps
     57            * 2得到tr 总记录数 通过 通过exprList生成where子句
     58            * 3得到beanlist
     59            * 4创建PageBean 返回
     60            */
     61           //得到ps
     62           int ps=PageConstants.BOOK_PAGE_SIZE;
     63           /*
     64            *总记录数 通过exprList生成where子句  select * from t_book where 1=1 and ..
     65            *条件语句不好控制所以为了后面统一  在前面先给个1=1 后面统一用and 开头 拼凑sql语句的一重要技巧
     66            */
     67           StringBuilder whereSql=new StringBuilder("where 1=1");
     68           List<Object> params=new ArrayList<Object>(); //它是对应问号的值
     69           
     70           for(Expression expr:exprList)
     71           {  
     72              whereSql.append(" and ").append(expr.getName()).append(" ").
     73              append(expr.getOpertator()).append(" "); 
     74               
     75              if(!expr.getOpertator().equals("is null"))
     76              {
     77                      whereSql.append("?");
     78                      params.add(expr.getValue());
     79              }
     80           }
     81           
     82           //总记录数
     83           String sql="select count(*) from t_book "+whereSql;
     84           Number number=(Number) qr.query(sql, new ScalarHandler(),params);
     85           int tr=number.intValue(); //得到了总记录数
     86           
     87           //得到beanList 即当前页记录
     88           sql = "select * from t_book " + whereSql + " order by orderBy limit ?,?";
     89           params.add((pc-1)*ps); //第一个问号 (2-1)*8 当前页首行记录的下标
     90           params.add(ps);  //一共查询几行
     91           List<Book> beanList=qr.query(sql, new BeanListHandler<Book>(Book.class),params.toArray());
     92           //丢了cid  若需要cid 改map 自己映射
     93           
     94           //创建pageBean 设置参数 其中pageBean 没有url这一项 这个任务由servlet来得到
     95           PageBean<Book> pb=new PageBean<Book>(); 
     96           pb.setPc(pc);
     97           pb.setPs(ps);
     98           pb.setTr(tr);
     99           pb.setBeanList(beanList);
    100      
    101           return pb;
    102       }
    103     
    104 
    105 }
    View Code

    BookService

     1 /*
     2  * 图书模块业务层
     3  */
     4 public class BookService {
     5     private BookDao bookDao = new BookDao();
     6 
     7     public PageBean<Book> findByCategory(String cid, int pc) {
     8 
     9         try {
    10             return bookDao.findByCategory(cid, pc);
    11         } catch (SQLException e) {
    12             throw new RuntimeException(e);
    13         }
    14 
    15     }
    16 
    17     // 按书名查询
    18 
    19     public PageBean<Book> findByBname(String bname, int pc) {
    20 
    21         try {
    22             return bookDao.findByBname(bname, pc);
    23         } catch (SQLException e) {
    24             throw new RuntimeException(e);
    25         }
    26 
    27     }
    28 
    29     // 按作者查询
    30     public PageBean<Book> findByAuthor(String author, int pc) {
    31 
    32         try {
    33             return bookDao.findByAuthor(author, pc);
    34         } catch (SQLException e) {
    35             throw new RuntimeException(e);
    36         }
    37 
    38     }
    39 
    40     // 按出版社查询
    41     public PageBean<Book> findByPress(String press, int pc) {
    42 
    43         try {
    44             return bookDao.findByAuthor(press, pc);
    45         } catch (SQLException e) {
    46             throw new RuntimeException(e);
    47         }
    48 
    49     }
    50    
    51     //多条件组合查询
    52     public PageBean<Book> findByCombination(Book criteria, int pc)
    53             throws SQLException {
    54         try {
    55             return bookDao.findByCombination(criteria, pc);
    56         } catch (SQLException e) {
    57             throw new RuntimeException(e);
    58         }
    59 
    60     }
    61 
    62 }
    View Code

    BookServlet

     1 //获取当前页码值
     2     private int getPc(HttpServletRequest req)
     3     {
     4         int pc=1;
     5         String param=req.getParameter("pc");
     6         if(param!=null&&!param.trim().isEmpty())
     7         {   
     8             try{
     9             pc=Integer.parseInt(param);
    10             }catch(RuntimeException e){}
    11         }
    12         return pc;
    13     }
    14 
    15     //获取url  截取url 页面中的分页导航中使用它作为超链接的目标  还带了条件 保证条件不丢
    16     private String getUrl(HttpServletRequest req)
    17     {    //http://localhost:8080//goods/BookServlet
    18         //getRequestURI()获取/goods/BookServlet
    19         //req.getQueryString()获取method=findByCategory&cid=xxx
    20         String url=req.getRequestURI()+"?"+req.getQueryString();
    21         //如果url中存在pc参数 截取掉 如果不存在则不用截取
    22         int index=url.lastIndexOf("&pc=");
    23         if(index!=-1)
    24         {
    25             url=url.substring(0,index);
    26         }
    27         return url;
    28     }
    29 
    30     public String findByCategory(HttpServletRequest req, HttpServletResponse resp)
    31             throws ServletException, IOException {
    32         
    33         //得到pc 如果页面传递使用页面的 如果没传pc=1
    34         int pc=getPc(req);
    35         
    36         //2得到url
    37         String url=getUrl(req);
    38         //3获取查询条件 本方法是cid 即分类id
    39         String cid=req.getParameter("cid");
    40         
    41         //使用pc cid 调用service 
    42         PageBean<Book> pb=bookService.findByCategory(cid,pc);
    43         //使用pageBean设置url 保存pageBean 转发到/jsps/book/list.jsp页面
    44          pb.setUrl(url); 
    45          req.setAttribute("pb", pb);
    46          return "f:/jsps/book/list.jsp";
    47        
    48         
    49     }
    View Code

    left.jsp

     1 <ul>
     2         <c:forEach items="${pb.beanList}" var="book">
     3         <li>
     4                 <div class="inner">
     5                     <a class="pic" href="<c:url value='/jsps/book/desc.jsp'/>"><img
     6                         src="<c:url value='/${book.image_b }'/>" border="0" /> </a>
     7                     <p class="price">
     8                         <span class="price_n">&yen;${book.currPrice}</span> 
     9                         <span class="price_r">&yen;${book.price}</span>
    10                         (<span class="price_s">${book.discount}折</span>)
    11                     </p>
    12                     <p>
    13                         <a id="bookname"
    14                             title="${book.bname }"
    15                             href="<c:url value='/jsps/book/desc.jsp'/>">${book.bname }</a>
    16                     </p>
    17                     <p>
    18                         <a href="<c:url value='/jsps/book/list.jsp'/>" name='P_zz'
    19                             title='Craig Walls'>${book.author }</a>
    20                     </p>
    21                     <p class="publishing">
    22                         <span>出 版 社:</span><a href="<c:url value='/jsps/book/list.jsp'/>">${book.press} }</a>
    23                     </p>
    24                     <p class="publishing_time">
    25                         <span>出版时间:</span>${book.publishtime}
    26                     </p>
    27                 </div></li>
    28         </c:forEach>
    29 
    30 
    31     </ul>
  • 相关阅读:
    frame、window和dialog区别
    wxWidgets窗口类型
    C++中类与结构体的区别
    c++中explicit关键字用法
    解决error C2011: 'fd_set' : 'struct' type redefinition的方法
    jrtplib源码分析 第一篇 jthread的编译与分析
    详解大端模式和小端模式
    C++——重点复习
    Linux组件封装(九)——EchoLib的一些简单综合
    Linux组件封装(八)——Socket的封装
  • 原文地址:https://www.cnblogs.com/xiaoying1245970347/p/4780610.html
Copyright © 2011-2022 走看看