博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springmvc工具类封装RowMapper
阅读量:5894 次
发布时间:2019-06-19

本文共 4426 字,大约阅读时间需要 14 分钟。

hot3.png

springmvc通常是先写实体,在数据库查询,最后增删改差,最感觉代码很冗余,自己在封装了一下。

常见的结构是:

entity:如

package com.liuxinquan.entiry;/** * @author:lxq * @类说明:Book *  */public class Book {	private String id;	private String user_id;	private String item_id;	private String prefer;	private String time;	public String getId() {		return id;	}	public String getUser_id() {		return user_id;	}	public void setUser_id(String user_id) {		this.user_id = user_id;	}	public String getItem_id() {		return item_id;	}	public void setItem_id(String item_id) {		this.item_id = item_id;	}	public String getPrefer() {		return prefer;	}	public void setPrefer(String prefer) {		this.prefer = prefer;	}	public String getTime() {		return time;	}	public void setTime(String time) {		this.time = time;	}	public void setId(String id) {		this.id = id;	}}

object:如

package com.liuxinquan.object;import java.sql.ResultSet;import java.sql.SQLException;import org.springframework.jdbc.core.RowMapper;import com.liuxinquan.entiry.Book;/** * @author:lxq * @类说明:bookobject *  */public class BookObj implements RowMapper
{ @Override public Book mapRow(ResultSet rs, int arg1) throws SQLException { Book book = new Book(); book.setId(rs.getString("id")); book.setItem_id(rs.getString("item_id")); book.setPrefer(rs.getString("prefer")); book.setTime(rs.getString("time")); book.setUser_id(rs.getString("user_id")); return book; } }

service

package com.liuxinquan.service;import java.util.List;import javax.annotation.Resource;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.stereotype.Service;import com.liuxinquan.entiry.Book;import com.liuxinquan.utils.CommonObj;/** * @author: @类说明: *  */@Servicepublic class BookService {	@Resource(name = "jdbcTemplate")	public JdbcTemplate jdbcTemplate;	public List
findAll() { String sql = "select * from recommender_prefer "; List
books = jdbcTemplate.query(sql, new bookObj()); return books; } public Book findbyId(String id) { String sql = "select * from recommender_prefer where id =" + id; Book book = jdbcTemplate.queryForObject(sql, new BookObj()); return book; } }

下面是简化的工具类

要是有很多实体,每写一个,都要重复这3个,效率很低,其中后两个是可以封装工具类:通用object

package com.liuxinquan.utils;import java.lang.reflect.Field;import java.sql.ResultSet;import java.sql.SQLException;import org.springframework.jdbc.core.RowMapper;/** * @author:lxq * @类说明:通用dao工具 *  */public class CommonObj implements RowMapper {	private Class
cl; public CommonObj(Class
cl) { this.cl = cl; } @Override public Object mapRow(ResultSet rs, int i) throws SQLException { try { Field[] fields = cl.getDeclaredFields(); Object entity = cl.newInstance(); for (Field f : fields) { f.setAccessible(true); this.typeMapper(f, entity, rs); f.setAccessible(false); } return entity; } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } return null; } private void typeMapper(Field field, Object obj, ResultSet rs) throws Exception { String type = field.getType().getName(); if (type.equals("java.lang.String")) { field.set(obj, rs.getString(field.getName())); } else if (type.equals("int") || type.equals("java.lang.Integer")) { field.set(obj, rs.getInt(field.getName())); } else if (type.equals("long") || type.equals("java.lang.Long")) { field.set(obj, rs.getLong(field.getName())); } else if (type.equals("boolean") || type.equals("java.lang.Boolean")) { field.set(obj, rs.getBoolean(field.getName())); } else if (type.equals("java.util.Date")) { field.set(obj, rs.getDate(field.getName())); } }}
这个可以放在utils中,具体用法如下:
package com.liuxinquan.service;import java.util.List;import javax.annotation.Resource;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.stereotype.Service;import com.liuxinquan.entiry.Book;import com.liuxinquan.utils.CommonObj;/** * @author: @类说明: *  */@Servicepublic class BookService {	@Resource(name = "jdbcTemplate")	public JdbcTemplate jdbcTemplate;	public List findAll() {		String sql = "select * from recommender_prefer ";		List books = jdbcTemplate.query(sql, new CommonObj(Book.class));		return books;	}	public Object findbyId(String id) {		String sql = "select * from recommender_prefer where id =" + id;		Object book = jdbcTemplate.queryForObject(sql, new CommonObj(Book.class));		return book;	}	}

service亦可以简化的,网上有很多,关于通用增删改查,自己可以搜一下。希望能有所帮助。

转载于:https://my.oschina.net/liuxinquan/blog/615922

你可能感兴趣的文章
android OTA差分包的生成方法
查看>>
恢复/boot下initramfrs文件
查看>>
oracle介质恢复和实例恢复的异同
查看>>
Python学习日记---集合
查看>>
PHP二进制与字符串之间的相互转换
查看>>
windowns 添加路由
查看>>
【物联网智能网关-03】GPRS模块中文短信收发
查看>>
读了这篇文章 AIX误删除数据的恢复将变得非常简单
查看>>
Oracle数据库误删除数据3种恢复语句
查看>>
浅析开源数据库MySQL架构
查看>>
软件测试的基本知识
查看>>
LNMP架构搭建
查看>>
Forrester:2017年度安全分析平台厂商评估(Forrester Wave)
查看>>
oracle基本命令随笔(2)
查看>>
不安装Oracle客户端也能使用PL/SQL
查看>>
WebBuilder7 在Linux、Tomcat、MySQL下配置注意事项
查看>>
word转html(一)
查看>>
我的友情链接
查看>>
如何高效进行OA系统选型
查看>>
很奇怪的问题。点击button会自动刷新页面?
查看>>