SSH中增删改查的封装实现

我们在使用SSH的时候,比如说User、Admin等实体对象,都有共同的增删改查方法,那么我们如何实现哪,看下边的例图:

这种类型的结构图,大家在开中可能会经常行的用到,例如下边这个项目实例:

其中:

(1)BaseDao是增删改查的接口定义,是一个父接口,下边的UserDao和RoleDao都会继承该接口;

(2)BaseDaoImpl是增删改查接口的实现类,是一个父类,下边的UserDaoImpl和RoleDaoImpl都继承了该接口;

(3)UserDao和RoleDao就是他们自己的方法定义的接口;

看代码如下:

BaseDao.java

import java.util.List;

public interface BaseDao<T> {
    void save(T entity);
    void delete(long id);
    void update(T entity);
    T getById(long id);
    List<T> findAll();
    List<T> getByIdS(Long[] ids);
}

BaseDaoImpl.java

import java.lang.reflect.ParameterizedType;
import java.util.List;
import javax.annotation.Resource;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
public class BaseDaoImpl<T> implements BaseDao<T> {

    @Resource
    private SessionFactory sessionFactory; // 获取sessionFactory对象
    private Class<T> clazz; // 表示当前的类型

    /**
     * 通过反射技术获得子类T的真实值
     *
     * 由于在子类中首先调用的是父类的构造方法
     */
    public BaseDaoImpl() {
        ParameterizedType pt = (ParameterizedType) this.getClass()
                .getGenericSuperclass();// 获取当前new的对象的泛型的父类类型
        clazz = (Class<T>) pt.getActualTypeArguments()[0]; // 获取第一个类型参数的真实类型
    }

    /**
     * protected:在子类中可以直接使用
     */
    protected Session getSession() {
        return sessionFactory.getCurrentSession();
    }

    public void save(T entity) {
        getSession().save(entity);
    }

    public void delete(long id) {
        Object object = getById(id); // 首先取到这个对象
        if (object != null) {
            getSession().delete(object);// 当对象不为空的时候删除该对象
        }
    }

    public void update(T entity) {
        getSession().update(entity);
    }

    @SuppressWarnings("unchecked")
    public T getById(long id) {
        return (T) getSession().get(clazz, id);
    }

    @SuppressWarnings("unchecked")
    public List<T> findAll() {
        return getSession().createQuery("FROM " + clazz.getSimpleName()).list();
    }

    @SuppressWarnings("unchecked")
    public List<T> getByIdS(Long[] ids) {
        return getSession().createQuery(//
                "FROM " + clazz.getSimpleName() + " WHERE id IN(:ids)")//
                .setParameterList("ids", ids)//
                .list();
    }
}

这里的一个关键技术就是:如何获得泛型中的T的确定类型,这里是通过反射的机制获取的。

然后下边几个基础的类,知识确定了继承和实现关系,其他的什么都没有做,

public class RoleDaoImpl extends BaseDaoImpl<Role> implements RoleDao {}
public class UserDaoImpl extends BaseDaoImpl<User> implements UserDao {}
public interface RoleDao extends BaseDao<Role> {}
public interface UserDao extends BaseDao<User> {}
时间: 2024-12-18 00:18:46

SSH中增删改查的封装实现的相关文章

iOS sqlite 增删改查 简单封装(基于 FMDB)

/** *  对 sqlite 的使用进行简单封装,仅涉及简单的单表 增删改查 * *  基于 FMDB * *  操作基于 model ,数据库表字段与 model 属性一一对应,对 model 整体进行操作 * *  根据 model 对象自动建表,字段类型只支持 NSString , NSIteger , float * *  用到 runtime 运行时获取 model 属性 * */ 1 // 2 // AGDatabaseManager.h 3 // 4 // Created by

php中增删改查以及返回结果(一)

虽然毕业后找的第一份正式的工作并不那么令人满意,但是在度过最初的迷茫期后,自己还是决定成为一个程序猿. 最近也是利用上班偶尔闲下来的时间,开始看书,撸代码,写一些小程序. 这两个礼拜主要的写的都是有关Ajax方面的代码,现在也算做一个小总结吧. JS方面的先不说了,自己弄得也比较少,还是先说下php方面的把.由于程序写的比较简单,也没用到框架什么的,就是单纯100来行代码. 1.数据库连接(面向对象方式) @ $db = mysqli('address','username','password

iOS SQLite 增删改查的封装(关系型)

在工程里导入libsqlite3.tbd库(Xcode 7) #import <UIKit/UIKit.h> @interface AppDelegate : UIResponder <UIApplicationDelegate> @property (strong, nonatomic) UIWindow *window; @end #import "AppDelegate.h" #import "RootViewController.h"

ThinkPHP 购物商城网站(数据库中增删改查的功能实现)——————重点——————

控制器 ---------------------GoodsController.class.php------------------------------------------------- <?php namespace Admin\Controller; use Think\Controller; class GoodsController extends Controller{ public function showlist1(){ // $goods=new GoodsMode

ssh简单增删改查分页

action: public class caraction extends ActionSupport{ private List<Car> list=new ArrayList(); private List<Cartyper> ctlist=new ArrayList(); private carbiz cbiz; private Car car; private Cartyper ct; private int y;public String carall(){ list=

DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)

一.DAO模式简介 DAO即Data Access Object,数据访问接口.数据访问:故名思义就是与数据库打交道.夹在业务逻辑与数据库资源中间. DAO模式实际上是两个模式的组合,即Data Accessor (数据访问者)模式和 Active Domain Object(领域对象)模式.Data Accessor 模式实现了数据访问和业务逻辑的分离:Active Domain Object 模式实现了业务数据的对象化封装. 需要注意的是,DAO设计模式是Java EE中的设计模式,而非Ja

封装HibernateUtil(静态单例模式)和增删改查方法

封装HibernateUtil import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; public class HibernateUtil { //定义常量是为了实现单例,不让随便new //ThreadLocal<Session>不是集合,是线程锁,为了单线程安全 private static final ThreadLocal<

MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)

[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4059514.html 联系方式:[email protected] [正文] 一.DAO模式简介 DAO即Data Access Object,数据访问接口.数据访问:故名思义就是与数据库打交道.夹在业务逻辑与数据库资源中间. DAO模式实际上是两个模式的组合,即Data Accessor (数据

BootstrapTable+KnockoutJS实现增删改查解决方案

BootstrapTable+KnockoutJS实现增删改查解决方案 前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4的语法,虽然没有完全掌握,但是算是有了一个大致的了解.于是乎有了今天的这篇文章:通过T4模板快速生成页面. KnockoutJS系列文章: JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(