ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:93.91KB ,
资源ID:24044245      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/24044245.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(分页查询SpringMVC+JDBC.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

分页查询SpringMVC+JDBC.docx

1、分页查询SpringMVC+JDBC本文通过一个实例,详细地说明了如何用SpringMVC进行数据库查询并且分页显示开发环境:操作系统:windows XP sp3数据库:Oracle10gIDE:MyEclipse6Web容器:Tomcat5.xJDK版本:JDK1.6工程切图如下基本上参照之前示例修改得来,重点关注SimpleJdbcTemplate与JdbcTemplate用法 以下只列出比较重要的类 UserController.java package com.liuzd.sj.web;import java.util.List;import javax.annotation.Res

2、ource;import javax.servlet.http.HttpServletRequest;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.PathVariable;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.SessionAttributes;import org.sp

3、ringframework.web.servlet.ModelAndView;import com.liuzd.page.Page;import com.liuzd.sj.entity.User;import com.liuzd.sj.service.UserService;ControllerRequestMapping(/user)SessionAttributes(userList)public class UserController extends BaseController private UserService userService; public UserService g

4、etUserService() return userService; Resource public void setUserService(UserService userService) this.userService = userService; RequestMapping(/userList) public ModelAndView userList(HttpServletRequest request) StringBuilder querySql = new StringBuilder(); querySql.append(select * from users where

5、1=1 ); String oracleQuerySql = querySql.toString(); /获取总条数 Long totalCount = new Long(this.getUserService().pageCounts(oracleQuerySql); /设置分页对象 Page page = executePage(request,oracleQuerySql,totalCount, id desc ); ModelAndView mv = new ModelAndView(); /查询集合 List users = this.getUserService().pageLis

6、t(page.getQuerySql(); mv.addObject(userList,users); mv.setViewName(userList); return mv; RequestMapping(/addUser) public ModelAndView addUser(HttpServletRequest request,User user) System.out.println(ADD USER: + user); this.userService.addUser(user); return userList(request); RequestMapping(/toAddUse

7、r) public String toAddUser() return addUser; RequestMapping(/delUser/id) public ModelAndView delUser(PathVariable(id) String id,HttpServletRequest request) this.userService.delUser(new User().setId(id); return userList(request); RequestMapping(/getUser/id) public ModelAndView getUser(PathVariable(id

8、) String id) User user = this.userService.getUserById(new User().setId(id); ModelAndView mv = new ModelAndView(updateUser); mv.addObject(user,user); return mv; RequestMapping(/updateUser) public ModelAndView editUser(User user,HttpServletRequest request) System.out.println(编辑: +user); this.userServi

9、ce.editUser(user); return userList(request); BaseController.java package com.liuzd.sj.web;import javax.servlet.http.HttpServletRequest;import com.liuzd.page.Page;import com.liuzd.page.PageState;import com.liuzd.page.PageUtil;/* *Title: *Description: *Copyright: Copyright (c) 2011 *Company: *Makedate

10、:2011-5-23 下午03:31:03 * author liuzidong * version 1.0 * since 1.0 * */public class BaseController /* * oracel的三层分页语句 * 子类在展现数据前,进行分页计算! * param querySql 查询的SQL语句,未进行分页 * param totalCount 根据查询SQL获取的总条数 * param columnNameDescOrAsc 列名+排序方式 : ID DESC or ASC */ protected Page executePage(HttpServletRequ

11、est request,String querySql,Long totalCount,String columnNameDescOrAsc) String oracleSql = PageUtil.createQuerySql(querySql,columnNameDescOrAsc); if(null = totalCount) totalCount = 0L; /*页面状态,这个状态是分页自带的,与业务无关*/ String pageAction = request.getParameter(pageAction); String value = request.getParameter

12、(pageKey); /*获取下标判断分页状态*/ int index = PageState.getOrdinal(pageAction); Page page = null; /* * index 1 只有二种状态 * 1 当首次调用时,分页状态类中没有值为 NULL 返回 -1 * 2 当页面设置每页显示多少条: index=0,当每页显示多少条时,分页类要重新计算 * */ Page sessionPage = getPage(request); if(index 1) page = PageUtil.inintPage(oracleSql,totalCount,index,value

13、,sessionPage); else page = PageUtil.execPage(index,value,sessionPage); setSession(request,page); return page; private Page getPage(HttpServletRequest request) Page page = (Page)request.getSession().getAttribute(PageUtil.SESSION_PAGE_KEY); if(page = null) page = new Page(); return page; private void

14、setSession(HttpServletRequest request,Page page) request.getSession().setAttribute(PageUtil.SESSION_PAGE_KEY,page); UserRowMapper.java package com.liuzd.sj.dao;import java.sql.ResultSet;import java.sql.SQLException;import org.springframework.jdbc.core.RowMapper;import com.liuzd.sj.entity.User;public

15、 class UserRowMapper implements RowMapper public UserRowMapper() public User mapRow(ResultSet rs, int index) throws SQLException User user = new User( rs.getString(id), rs.getString(name), rs.getString(password), rs.getString(address), rs.getString(sex), rs.getInt(age) ); return user; UserDAOImpl.ja

16、va package com.liuzd.sj.dao.impl;import java.sql.PreparedStatement;import java.sql.SQLException;import java.util.List;import javax.annotation.Resource;import org.springframework.jdbc.core.BeanPropertyRowMapper;import org.springframework.jdbc.core.PreparedStatementSetter;import org.springframework.st

17、ereotype.Repository;import com.liuzd.sj.dao.UserDAO;import com.liuzd.sj.dao.UserRowMapper;import com.liuzd.sj.entity.User;Repository(userDao)public class UserDAOImpl implements UserDAO private static final String INSERT = insert into users(id,name,age,sex,address,password)VALUES(?,?,?,?,?,?); privat

18、e static final String UPDATE = update users set name=?,age=?,sex=?,address=?,password=? where id=?; private static final String GET = select * from users where id=?; private static final String CHECK = select count(1) from users where name=? and password=?; private static final String SELECT = selec

19、t * from users; private static final String DEL = delete users where id=?; private org.springframework.jdbc.core.JdbcTemplate jdbcTemplate; public org.springframework.jdbc.core.JdbcTemplate getJdbcTemplate() return jdbcTemplate; Resource public void setJdbcTemplate( org.springframework.jdbc.core.Jdb

20、cTemplate jdbcTemplate) this.jdbcTemplate = jdbcTemplate; public void addUser(final User user) getJdbcTemplate().update(INSERT, new PreparedStatementSetter() public void setValues(PreparedStatement ps) throws SQLException int i = 0; ps.setString(+i, user.getId(); ps.setString(+i, user.getName(); ps.

21、setInt(+i, user.getAge(); ps.setString(+i,user.getSex(); ps.setString(+i,user.getAddress(); ps.setString(+i,user.getPassword(); ); public int checkUserExits(User user) return getJdbcTemplate().queryForInt(CHECK, user.getName(),user.getPassword(); public void delUser(User user) getJdbcTemplate().upda

22、te(DEL, user.getId(); public void editUser(final User user) getJdbcTemplate().update(UPDATE, new PreparedStatementSetter() public void setValues(PreparedStatement ps) throws SQLException int i = 0; ps.setString(+i, user.getName(); ps.setInt(+i, user.getAge(); ps.setString(+i,user.getSex(); ps.setStr

23、ing(+i,user.getAddress(); ps.setString(+i,user.getPassword(); ps.setString(+i, user.getId(); ); public List getAllUser() return getJdbcTemplate().query(SELECT, new BeanPropertyRowMapper(User.class); public User getUserById(User user) return getJdbcTemplate().queryForObject(GET, new UserRowMapper(),u

24、ser.getId(); public int pageCounts(String querySql) return getJdbcTemplate().queryForInt(select count(1) from(+querySql+); public List pageList(String querySql) return getJdbcTemplate().query(querySql, new UserRowMapper(); UserDAOImpl2.java package com.liuzd.sj.dao.impl;import java.util.List;import

25、java.util.Map;import javax.annotation.Resource;import org.springframework.jdbc.core.BeanPropertyRowMapper;import org.springframework.stereotype.Repository;import com.liuzd.sj.dao.UserDAO;import com.liuzd.sj.entity.User;import com.liuzd.util.BeanToMapUtil;Repository(userDao2)public class UserDAOImpl2

26、 implements UserDAO private static final String INSERT = insert into users(id,name,age,sex,address,password)VALUES(:id,:name,:age,:sex,:address,:password); private static final String UPDATE = update users set name=:name,age=:age,sex=:sex,address=:address,password=:password where id=:id; private sta

27、tic final String GET = select * from users where id=?; private static final String CHECK = select count(1) from users where name=? and password=?; private static final String SELECT = select * from users; private static final String DEL = delete users where id=?; private org.springframework.jdbc.cor

28、e.simple.SimpleJdbcTemplate simpleJdbcTemplate; public org.springframework.jdbc.core.simple.SimpleJdbcTemplate getSimpleJdbcTemplate() return simpleJdbcTemplate; Resource public void setSimpleJdbcTemplate( org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate) this.simpleJdbcTemplate = simpleJdbcTemplate; public void addUser(final User user) Map userMap = BeanToMapUtil.beanToMap(user); getSimpleJdbcTemplate().update(INSERT, userMap); public int checkUserExits(User user) return getSimpleJdbcTemplate().queryForInt(CHECK, user.getName(),user.getPassword(); public void

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1