之前写过一篇JSP+Servlet+javabean+mysql实现页面多条件模糊查询 使用的是mysql进行的分页查询,mysql用limit控制,而oracle则是用rownum,今天第一次写oracle,查了一下资料试了一下,把代码帖出来

oracle的数据源配置也不同:

driverName=oracle.jdbc.driver.OracleDriver
url=jdbc\:oracle\:thin\:@127.0.0.1\:1521\:orcl
username=marketManager
pwd=marketManager

直接帖实现类(特别注意红色代码体):

package pb.market.com.cn.dao.impl;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List; import pb.market.com.cn.dao.ProviderDao;
import pb.market.com.cn.pojo.Provider;
import pb.market.com.cn.util.BaseDao; public class ProviderDaoImpl extends BaseDao implements ProviderDao { //获取供应商列表
public List<Provider> getProviderList(int pageNo, int pageSize, String where) {
List<Provider> providerList =new ArrayList<Provider>();
String sql="select * from ( select rownum as r,a.* from gongyingshang a where "+where+" rownum<=? ) where r>?";
Object[] params ={pageSize*pageNo,(pageNo-1)*pageSize};
if(this.getConnection()){
System.out.println(sql);
ResultSet rs = this.executeQuery(sql, params);
try {
while(rs.next()){
Provider provider = new Provider();
provider.setId(rs.getInt("id"));
provider.setGysno(rs.getInt("gysno"));
provider.setGysname(rs.getString("gysname"));
provider.setGystel(rs.getString("gystel"));
provider.setGysfax(rs.getString("gysfax"));
provider.setCreatedate(rs.getTimestamp("createdate"));
provider.setCreateby(rs.getString("createby"));
provider.setModifydate(rs.getTimestamp("modifydate"));
provider.setModifyby(rs.getString("modifyby"));
providerList.add(provider); }
} catch (SQLException e) {
e.printStackTrace();
}finally{
this.closeConnection();
}
}
return providerList;
}
/*public static void main(String[] args) { ProviderDao dd=new ProviderDaoImpl();
String where="金";
String where1="gysname like '%"+where+"%' and";
List<Provider> providerList =dd.getProviderList(1, 5, where1); for (Provider provider : providerList) {
System.out.println("11111111111111");
System.out.println(provider.getId());
} }*/ //获取供应商总数量
public int getProviderCount(String where) {
int count=0;
String sql="select count(*)as count from gongyingshang "+where;
Object[] params={};
if(this.getConnection()){
ResultSet rs =this.executeQuery(sql, params);
try {
if(rs.next()){
count = rs.getInt("count");
}
} catch (SQLException e) {
e.printStackTrace();
}finally{
this.closeConnection();
}
}
return count;
}
}

中间的service实现类,我的业务较简单,service层基本不做什么,只是调用一下dao层实现类的方法而已:

package pb.market.com.cn.service.impl;

import java.util.List;

import pb.market.com.cn.dao.ProviderDao;
import pb.market.com.cn.dao.impl.ProviderDaoImpl;
import pb.market.com.cn.pojo.Provider;
import pb.market.com.cn.service.ProviderService; public class ProviderServiceImpl implements ProviderService {
private ProviderDao providerDao;
public ProviderServiceImpl(){
providerDao=new ProviderDaoImpl();
}
public List<Provider> getProviderList(int pageNo, int pageSize, String where) {
return providerDao.getProviderList(pageNo, pageSize, where);
}
public int getProviderCount(String where) {
return providerDao.getProviderCount(where);
} }

servlet:

package pb.market.com.cn.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.List; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import pb.market.com.cn.pojo.Provider;
import pb.market.com.cn.service.ProviderService;
import pb.market.com.cn.service.impl.ProviderServiceImpl; public class ProviderListServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
try{
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
ProviderService providerService =new ProviderServiceImpl();
StringBuffer sb =new StringBuffer(1024);
StringBuffer sb1 =new StringBuffer(1024);
//获取模糊查询的值
String where = request.getParameter("proName");
//System.out.println("where================="+where);
//如果为空
if(where!=null && !"".equals(where)){
sb.append("where gysname like '%"+where+"%'");
sb1.append("gysname like '%"+where+"%' and");
}
//设置每页显示3条
int pageSize=3;
//得总条数
int totalCount =providerService.getProviderCount(sb.toString()); //得到总页数,如果总页数对一页的量取模==0,则。。。
int totalPageCount=0;
if((totalCount%pageSize)==0){
totalPageCount=totalCount/pageSize;
}else{
totalPageCount=totalCount/pageSize +1;
}
//获取当前页,默认一打开进来即是第1页
String pageIndex = request.getParameter("pageIndex");
//System.out.println("pageIndex==============="+pageIndex);
int currentPageNo=0;
if(pageIndex==null){
currentPageNo=1;
}else{
//System.out.println("这里怎么可能进得来???????????");
currentPageNo= Integer.parseInt(pageIndex);
} // 首页和尾页的异常控制
if (currentPageNo <= 0) {
currentPageNo = 1;
} else if (currentPageNo > totalPageCount) {
currentPageNo = totalPageCount;
}
//把各个页码传给JSp
request.setAttribute("pageSize", pageSize);
request.setAttribute("totalCount", totalCount);
request.setAttribute("totalPageCount", totalPageCount);
request.setAttribute("currentPageNo", currentPageNo);
//获取providerList
List<Provider> providerList = providerService.getProviderList(currentPageNo, pageSize, sb1.toString());
request.setAttribute("providerList", providerList);
request.getRequestDispatcher("/jsp/providerList.jsp").forward(request, response); }catch(Exception e){
e.printStackTrace();
} } public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response); } }

后面的JSP页面我就省略不写了。。。。。跟文头说的那篇mysql流程是一样,写法也类似

JSP+Servlet+javabean+oracle实现页面多条件模糊查询的更多相关文章

  1. JSP+Servlet+javabean+mysql实现页面多条件模糊查询

    需求: 一般列表页上面会有一个查询框,有各种的查询条件组合,一般都采用模糊查询方式 ,以下以自己做的实例来说明一下实现方法: 需要实现的界面原型:要满足条件: 1.单选分类,点GO按扭 2.单独输入标 ...

  2. 深入浅出Java MVC(Model View Controller) ---- (JSP + servlet + javabean实例)

    在DRP中终于接触到了MVC,感触是确实这样的架构系统灵活性不少,现在感触最深的就是使用tomcat作为服务器发布比IIS好多了,起码发布很简单,使用起来方便. 首先来简单的学习一下MVC的基础知识, ...

  3. JSP中使用的模式——JSP+Servlet+JavaBean

    上一篇博文写到模式一:JSP+JavaBean 链接地址:http://wxmimperio.coding.io/?p=155 JSP中两种模式的总结 链接地址:http://wxmimperio.c ...

  4. MVC jsp+servlet+javabean 连接Mysql数据库測试demo

    本文介绍的是怎样使用MVC架构去实现jsp+servlet+javabean连接数据库 首先我们应该了解什么是MVC: MVC包含三个部分 : ①View:由各种JSP页面组成. ②Controlle ...

  5. jsp+servlet+javabean开发web项目

    一.介绍: 项目依赖包:jdbc数据库包 jsp+servlet+javabean开发web项目,是最接近web项目原生运行原理的. 但是,jsp内容混乱,项目结构复杂时,代码会混乱 二.运行原理: ...

  6. (jsp+servlet+javabean )MVC架构

    MVC是三个单词的缩写,这三个单词分别为:模型.视图和控制. 使用的MVC的目的:在于将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式.比如Windows系统资源管理器文件夹内容的显示方 ...

  7. Jsp+Servlet+JavaBean经典MVC模式理解

    MVC模式目的(实现Web系统的职能分工). 在Java EE中,Jsp+Servlet+JavaBean算是里面经典的模式,是初学者必备的知识技能.M, Model(模型)实现系统的业务逻辑 1.通 ...

  8. asp下实现多条件模糊查询SQL语句

    常写一个简单的模糊查询的SQL语句格式可以如下例: sql="select * from 表名 where 字段名 like ’%" & request.form(&quo ...

  9. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架 ...

随机推荐

  1. 探究JVM——垃圾回收

    垃圾回收主要考虑三件事情:哪些内存需要回收?什么时候回收?如何回收? 一.哪些内存需要回收? 堆内存:对于JVM 来说,垃圾回收主要是针对堆内存中的对象实例. 方法区:垃圾收集行为在方法区是比较少出现 ...

  2. [HDU5902]GCD is Funny(xjb搞)

    题意:n个数每次选三个数删除,取其中两个数将gcd放回去两次,问最后剩的数可能是多少 分析:考虑最优情况: 先拿出三个数,留下两个x,x  再来一个y,(x,x,y)我们可以删去一个x,留下两个gcd ...

  3. android之fragment的使用

    android中的fragment与html中的div很类似,下图中通过左边的按键可以控制右边的显示内容.右边的内容就是一个fragment,通过点击按键来控制fragment的实现. 工程目录 需要 ...

  4. XML的解析和保存

    1.XML(extensible markup language;XML )  定义:,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言.     XML语法规范:  标 ...

  5. javascript 函数声明与函数表达式的区别

    先看一段代码 var f = function g() { return 1; }; if (false) { f = function g(){ return 2; }; } alert(g()); ...

  6. BroadcastReceiver之发送自定义无序广播

    首先,发送一个自定义广播:(用sendBroadcast(intent)发送一条无序广播) public void click(View v){ Intent intent = new Intent( ...

  7. Firefox about

    在firefox的地址栏输入about:about,然后看一下各个链接.有的链接有具体的用途,有的链接疯言疯语,并无软用. about:about集中了火狐浏览器的全部用户界面,平时常见的prefer ...

  8. 【Python】[函数] 调用与定义

    1.数据类型转换 int(),float(),str(),bool('1')2.定义函数使用 def关键字,依次写出 函数名.括号.括号中的参数.冒号,然后在缩进体中写函数内容 例子 求绝对值的函数 ...

  9. 屠龙之路_大杀技之倚天屠龙_TenthDay

    惊天变! alhpa恶龙终于现身了!随之出现是屠龙天团的少年们多时不见的公主.alpha恶龙虽然元气大伤.意识不清,但是它庞大的身躯只要稍微动弹,足以重创在场的所有少年,以及现在还被恶龙牢牢囚在手心的 ...

  10. extjs 箱子布局

    a.flex 配置项 flex 配置项不是设置在布局上,而是设置在子项的配置项.每个子项相对的 flex 值都会与全体子项 flex 累加的值相比较,根据此结果,处理每个子项的 flex 最后是多少. ...