mybatis-basedao的实现

时间:2022-09-02 15:55:01
package com.yangwei.shop.dao;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.ibatis.session.SqlSession;

import com.yangwei.shop.entity.Pager;
import com.yangwei.shop.entity.SystemContext;
import com.yangwei.shop.util.MyBatisUtil;
// 其中 Pager SystemContext 是自定义的分页类,前面mybatis有讲解 http://www.cnblogs.com/yangw/p/3315398.html
/**
 * BaseDao 使用泛型
 * 命令 :约定优于配置
 */
public class BaseDao<T> {

    public void add(T obj){

        SqlSession session=null;
        try {
            session = MyBatisUtil.createSession();
            //约定 namespace值是该实体类的全路径,并且所有的添加都是add
            session.insert(obj.getClass().getName()+".add", obj);
            session.commit();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }finally{
            MyBatisUtil.closeSession(session);
        }
    }

    public void update(T obj){
        SqlSession session=null;
        try {
            session = MyBatisUtil.createSession();
            //约定 namespace值是该实体类的全路径,并且所有的更新都是update
            session.update(obj.getClass().getName()+".update", obj);
            session.commit();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }finally{
            MyBatisUtil.closeSession(session);
        }
    }

    public void delete(Class<T> clazz,int id){
        SqlSession session=null;
        try {
            session = MyBatisUtil.createSession();
            //约定 namespace值是该实体类的全路径,并且所有的删除都是delete
            session.delete(clazz.getName()+".delete", id);
            session.commit();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }finally{
            MyBatisUtil.closeSession(session);
        }
    }
    /**
     * 根据Id查找
     */
    public T load(Class<T> clazz,int id){
        return this.load(clazz.getName()+"load", id);
    }
    /**
     * 根据指定的多个条件获取一条记录(最通用)
     */
    public T load(String sqlId,Map<String,Object> params){
        SqlSession session=null;
        T obj=null;
        try {
            session = MyBatisUtil.createSession();
            //约定 namespace值是该实体类的全路径,并且所有的根据Id加载都是load
            obj=session.selectOne(sqlId, params);
        }finally{
            MyBatisUtil.closeSession(session);
        }
        return obj;
    }
    /**
     * 根据指定的一个条件获取一条记录
     */
    public T load(String sqlId,Object param){
        SqlSession session=null;
        T obj=null;
        try {
            session = MyBatisUtil.createSession();
            //约定 namespace值是该实体类的全路径,并且所有的根据Id加载都是load
            obj=session.selectOne(sqlId, param);
        }finally{
            MyBatisUtil.closeSession(session);
        }
        return obj;
    }

    /**
     * 有分页的查询 (默认是find)
     */
    public Pager<T> find(Class<T> clazz,Map<String,Object> params){

        return this.find(clazz.getName()+".find", params);

    }
    /**
     * 有分页的查询 (自行指定sqlId)
     */
    public Pager<T> find(String sqlId,Map<String,Object> params){

        int pageOffset=SystemContext.getPageOffset();
        int pageSize=SystemContext.getPageSize();
        String order=SystemContext.getOrder();
        String sort=SystemContext.getSort();
        Pager<T> pages=new Pager<T>();
        SqlSession session=null;

        try {
            session = MyBatisUtil.createSession();
            if(params==null) params=new HashMap<String,Object>();

            params.put("pageOffset", pageOffset);
            params.put("pageSize", pageSize);
            params.put("order", order);
            params.put("sort", sort);
            //约定 namespace值是该实体类的全路径,并且所有的分页查询都是find
            List<T> lists=session.selectList(sqlId, params);

            pages.setDatas(lists);
            pages.setPageOffset(pageOffset);
            pages.setPageSize(pageSize);
            //获取当前条件下的所有记录数
            //查询记录的命名是 XXX,那么约定记录条数命名是 XXX_count
            int count=session.selectOne(sqlId+"_count", params);
            pages.setTotalRecord(count);

        } finally{
            MyBatisUtil.closeSession(session);
        }
        return pages;

    }
    /**
     * 不带分页的查询 (默认是list)
     */
    public List<T> list(Class<T> clazz,Map<String,Object> params){

        return this.list(clazz.getName()+".list", params);

    }

    /**
     * 不带分页的查询 ,自行指定sqlId
     * 排序依然带着
     */
    public List<T> list(String sqlId,Map<String,Object> params){

        String order=SystemContext.getOrder();
        String sort=SystemContext.getSort();
        List<T> list=null;
        SqlSession session=null;

        try {
            session = MyBatisUtil.createSession();
            if(params==null) params=new HashMap<String,Object>();
            params.put("order", order);
            params.put("sort", sort);
            //约定 namespace值是该实体类的全路径,并且所有的分页查询都是find
            list=session.selectList(sqlId, params);
        } finally{
            MyBatisUtil.closeSession(session);
        }
        return list;

    }
}

部分mapper.xml

<mapper namespace="com.yangwei.shop.entity.Address">
    <insert id="add" parameterType="Address">
        insert into t_address (name,phone,postcode,user_id) value
            (#{name},#{phone},#{postcode},#{user.id})
    </insert>

    <update id="update" parameterType="Address">
        update t_address set
            name=#{name},phone=#{phone},postcode=#{postcode} where id=#{id}
    </update>

    <delete id="delete" parameterType="int">
        delete from t_address where id=#{id}
    </delete>
    <select id="load" parameterType="int" resultType="Address">
        select * from t_address where id=#{id}
    </select>
    <select id="find" parameterType="map" resultType="Address">
        select * from t_address
        <where>
            <if test="name!=null">
                name like #{name}
             </if>
        </where>
         <if test="sort!=null">
             order by ${sort}
             <if test="order!=null">
                 ${order}
             </if>
         </if>
        limit #{pageOffset},#{pageSize}
    </select>
    <select id="find_count" parameterType="map" resultType="int">
        select count(*) from t_address
         <where>
            <if test="name!=null">
                name like #{name}
             </if>
        </where>
        limit #{pageOffset},#{pageSize}
    </select>
    <select id="list" parameterType="map" resultType="Address">
        select * from t_address
        <where>
            <if test="name!=null">
                name like #{name}
             </if>
        </where>
         <if test="sort!=null">
             order by ${sort}
             <if test="order!=null">
                 ${order}
             </if>
         </if>
    </select>
    <!-- 下面是一些特殊的情况,即不是我们能提前约定的-->
    <select id="list_by_name" >
    </select>
    <select id="list_by_name_count" >
    </select>
    

再看看我们的dao变得如此之简洁

package com.yangwei.shop.dao;

import java.util.HashMap;
import java.util.Map;

import com.yangwei.shop.entity.Address;
import com.yangwei.shop.entity.Pager;

public class AddressDao extends BaseDao<Address> implements IAddressDao {

    @Override
    public void addAddress(Address address, int userId) {
        //1,略 根据userId去t_user表加载User信息
        //2,将User设置到address中
        //3,调用父类方法 添加
        super.add(address);
    }

    @Override
    public void updateAddress(Address address) {
        super.update(address);
    }

    @Override
    public void deleteAddress(int id) {
        super.delete(Address.class, id);
    }

    @Override
    public Address loadAddress(int id) {
        return super.load(Address.class, id);
    }

    @Override
    public Pager<Address> findAddress(String name) {

        Map<String, Object> params=new HashMap<String, Object>();
        if(name!=null && !"".equals(name)){
            params.put("name", "%"+name+"%");
        }
        return super.find(Address.class, params);
    }

}

mybatis-basedao的实现的更多相关文章

  1. 开发基础框架:mybatis-3&period;2&period;8 &plus;hibernate4&period;0&plus;spring3&period;0&plus;struts2&period;3

    一:项目下载地址(点击 Source code(zip)) https://github.com/fzxblgong/frame_2014-12-15/releases 版本:v1.2大小:20M 二 ...

  2. 基于mybatis的BaseDao及BaseService深度结合(转)

    原文地址:http://zhaoshijie.iteye.com/blog/2003209 关键字:Mybatis通用DAO设计封装(mybatis) 说明: mybatis默认分页机制为逻辑分页,所 ...

  3. 基于 Spring &plus; Atomikos &plus; Mybatis的多数据源配置(含有BaseDao&comma;BaseService)

    1.spring配置文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...

  4. Spring和Mybatis整合,配置文件

    整合时除了未整合前spring.mybatis的必须包外还需要加入两个包 spring-jdbc-4.2.5.RELEASE.jar mybatis-spring-1.2.5.jar spring-j ...

  5. 每日一记-mybatis碰到的疑惑:String类型可以传入多个参数吗

    碰到一个觉得很疑惑的问题,Mybatis的parameterType为String类型的时候,能够接收多个参数的吗? 背景 初学Mybatis的时候,看的教程和书籍上都是在说基本的数据类型如:int. ...

  6. 第一个spring、springmvc、mybatis、freemarker项目小知识(一)

    1.持久层开发(Mybatis)    1.1 添加,非空字段必须给值,不是非空加判断,有值添加无值不添    1.2 删除,注意外键关系的级联删除.(事务传播行为)    1.3 更新,每个字段单独 ...

  7. MyBatis Generator作为maven插件自动生成增删改查代码及配置文件例子

    什么是MyBatis Generator MyBatis Generator (MBG) 是一个Mybatis的代码生成器,可以自动生成一些简单的CRUD(插入,查询,更新,删除)操作代码,model ...

  8. mybatis 多个dao重名,根据namespace解析

    在mybatis通过执行sql语句的方式是,用getSqlSession().xxx(param,..)方法来调用, 其中第一个参数就是dao mapper.xml文件的命名空间.id package ...

  9. Spring&plus;Maven&plus;Dubbo&plus;MyBatis&plus;Linner&plus;Handlebars—Web开发环境搭建

    本文主要分三部分,分别是:后台核心业务逻辑.桥梁辅助控制和前台显示页面. 本Web开发环境综合了多种工具,包括Maven包管理与编译工具.Dubbo分布式服务框架.MyBatis数据持久化工具.Lin ...

  10. springMVC &plus; Spring &plus; MyBatis 整合

    整理下SSM(基于注解)的整合 1. web.xml 配置文件 <?xml version="1.0" encoding="UTF-8"?> &lt ...

随机推荐

  1. Oculus安装问题

    1.必须FQ,可采用蓝灯,或其他vpn 2.Your computer doesn't meet Rift's recommended specifications 如果某些硬件达不到推荐配置(比如我 ...

  2. CG资源网 - Maya教程

    Maya中mentalray灯光渲染终极训练视频教程 http://www.cgtsj.com/cg/f/vx3627/index.html Maya无人机建模制作训练视频教程第一季 http://w ...

  3. 在ECSHOP后台左侧导航中增加新菜单

    在ECSHOP后台左侧导航中增加新菜单 ECSHOP教程/ ecshop教程网(www.ecshop119.com) 2011-11-08   有个别高级用户(懂PHP的),提到这样的问题: 在后台管 ...

  4. spring security &plus;spring boot 自定义 403 页面

    用的spring security  做的权限控制, 当  访问没有权限, 跳转 会跳到默认403 页面.不符合当前项目需求. 一下是解决方式: package com.ycmedia; import ...

  5. Python基础(四)-集合

    补充: 数据类型分类: 1.按照数据可变不可变: 可变:列表.字典 不可变:数字.字符串.元组 x={':1} print(id(x)) x.update({':2}) print(x) print( ...

  6. 转载 ~shell简介

    Shell本身是一个用C语言编写的程序,它是用户使用Unix/Linux的桥梁,用户的大部分工作都是通过Shell完成的.Shell既是一种命令语言,又是一种程序设计语言.作为命令语言,它交互式地解释 ...

  7. 玩转web之ligerui&lpar;二&rpar;---前缀编码生成树(分级码)实现树型表格

    请珍惜小编劳动成果,该文章为小编原创,转载请注明出处. 背景:             在ligerui中(其他uI可能也大同小异),实现树形表格可以通过父子节点,也可以通过前缀编码生成树去实现,而使 ...

  8. &lbrack;再寄小读者之数学篇&rsqb;&lpar;2014-04-01 from 2103471050&commat;qq&period;com 曲线积分&rpar;

    求 $\int_\vGa y^2\rd s$, 其中 $\vGa$ 由 $\dps{\sedd{\ba{rl} x^2+y^2+z^2&=a^2\\ x+z&=a \ea}}$ 决定. ...

  9. linux中一些简便的命令之wc

    wc命令是统计文本中的字符数.单词数以及文本行数的,具体参数如下: -l 统计文本中的行数 -w 统计文本中的单词数 -c/m 统计文本中的字符数 -L 统计文本中最长行的字符数 当然使用时也可以不带 ...

  10. 【转】【MySQL】Mysql模糊查询like提速优化

    在使用msyql进行模糊查询的时候,很自然的会用到like语句,通常情况下,在数据量小的时候,不容易看出查询的效率,但在数据量达到百万级,千万级的时候,查询的效率就很容易显现出来.这个时候查询的效率就 ...