MyBatis实现基于Mapper接口代理Dao的CURD

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: MyBatis实现基于Mapper接口代理Dao的CURD

1.User类


package com.domain;
import java.io.Serializable;
import java.util.Date;
public class User implements Serializable{
    private Integer id;
    private String username;
    private String address;
    private String sex;
    private Date birthday;
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    public Date getBirthday() {
        return birthday;
    }
    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", address='" + address + '\'' +
                ", sex='" + sex + '\'' +
                ", birthday=" + birthday +
                '}';
    }
}

2.SqlMapConfig.xml主配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--配置环境-->
    <environments default="mysql">
        <environment id="mysql">
            <!--配置事务-->
            <transactionManager type="JDBC"></transactionManager>
            <!--配置连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"></property>
                <property name="url" value="jdbc:mysql://localhost:3306/eesy_mybatis"></property>
                <property name="username" value="root"></property>
                <property name="password" value="root"></property>
            </dataSource>
        </environment>
    </environments>
    <!--映射配置文件的位置-->
    <!--注意这里用/-->
    <mappers>
        <mapper resource="com/dao/IUserDao.xml"></mapper>
    </mappers>
</configuration>

3.IUserDao接口

package com.dao;
import com.domain.QueryVo;
import com.domain.User;
import java.util.List;
//用户的持久层接口
public interface IUserDao {
    //查询所有
    List<User> findall();
    //根据id查询
    User findbyid(Integer id);
    /**
     *保存用户
     * @param user
     * @return 影响数据库记录的行数
     */
    int saveuser(User user);
    /**
     * 更新用户
     * @param user
     * @return
     */
    int updateUser(User user);
    /**
     * 根据id删除用户
     * @param id
     * @return
     */
    int deleteUser(Integer id);
    /**
     * 根据名称模糊查询
     * @param username
     * @return
     */
    List<User> finguserbyname(String username);
    /**
     * 查询总记录数
     * @return
     */
    int findtotal();
    /**
     * 根据QueryVo中的条件查询用户
     * @param vo
     * @return
     */
    List<User> findbyvo(QueryVo vo);
}

4.IUserDao.xml 用户的配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--namespace确定该方法在哪个dao接口中-->
<mapper namespace="com.dao.IUserDao">
    <!--id来确定是具体哪个方法-->
    <!--id+namespace确定了一个固定的方法-->
    <!--resulttype表示要封装到那里去-->
    <!--里面写的是sql语句-->
    <select id="findall" resultType="com.domain.User">
        SELECT * FROM user;
    </select>
    <!--select * from user where id = ? ;-->
    <!---->
    <select id="findbyid"  parameterType="INT" resultType="com.domain.User">
         select * from user where id = #{id};
    </select>
    <!--配置保存是获取插入的id-->
    <insert id="saveuser" parameterType="com.domain.User">
          <selectKey keyColumn="id" keyProperty="id" resultType="int">
            select last_insert_id();
          </selectKey>
          insert into user (username,birthday,sex,address)
          values(#{username},#{birthday},#{sex},#{address});
    </insert>
    <update id="updateUser" parameterType="com.domain.User">
        update user set username=#{username},birthday=#{birthday},sex=#{sex},
        address=#{address} where id=#{id}
    </update>
    <delete id="deleteUser" parameterType="java.lang.Integer">
        delete from user where id = #{id};
    </delete>
    <!--select * from user where username like #{username};-->
    <select id="finguserbyname" resultType="com.domain.User" parameterType="String">
            select * from user where username like '%${value}%';
    </select>
    <select id="findtotal" resultType="int">
        select count(*) from user;
    </select>
    <select id="findbyvo" resultType="com.domain.User" parameterType="com.domain.QueryVo">
        select * from user where username like #{user.username};
    </select>
</mapper>

5测试类MybatisTest

package com.test;
import com.dao.IUserDao;
import com.domain.QueryVo;
import com.domain.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import java.io.InputStream;
import java.util.Date;
import java.util.List;
//测试mybatis的crud方法
public class MybatisTest {
    private InputStream in ;
    private SqlSessionFactory factory;
    private SqlSession session;
    private IUserDao userDao;
    //    测试查询所有方法
    @Before
    //在测试之前执行
    public void init()throws Exception {
        //1.读取配置文件
        in = Resources.getResourceAsStream("SqlMapConfig.xml");
        //2.创建构建者对象
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        //3.创建 SqlSession 工厂对象
        factory = builder.build(in);
        //4.创建 SqlSession 对象
        session = factory.openSession();
        //5.创建 Dao 的代理对象
        userDao = session.getMapper(IUserDao.class);
    }
    //根据id来查询
    @Test
    public void testFindOne() {
        //6.执行操作
        User user = userDao.findbyid(41);
        System.out.println(user);
    }
    @Test
    public void saveuser(){
        User user = new User();
        user.setUsername("User property");
        user.setAddress("北京市顺义区");
        user.setSex("男");
        user.setBirthday(new Date());
        System.out.println("保存操作之前: "+user);
        //5.执行保存方法
        userDao.saveuser(user);
        System.out.println("保存操作之后: "+user);
    }
    @Test
    public void updateuser(){
        User user1 = userDao.findbyid(41);
        //更新操作
        user1.setAddress("河南");
        //更新用户
        int i = userDao.updateUser(user1);
        System.out.println(user1);
        System.out.println(i);
    }
    @Test
    public void deleteuser(){
        //根据id删除用户
    //    User user = userDao.findbyid(50);
        userDao.deleteUser(50);
    }
    @Test
    public void finduserbyname(){
        List<User> list = userDao.finguserbyname("王");
        for (int i = 0; i < list.size(); i++) {
            User user =  list.get(i);
            System.out.println(user);
        }
    }
    @Test
    public void findcount(){
        int findtotal = userDao.findtotal();
        System.out.println(findtotal);
    }
    //测试包装类作为参数,这个肯定远远不止这个简单的
    @Test
    public void testfindbyQueryVo(){
        //创建包装类
        QueryVo vo = new QueryVo();
        User user = new User();
        //封装对象
        user.setUsername("%王%");
        vo.setUser(user);
        List<User> list = userDao.findbyvo(vo);
        for (int i = 0; i < list.size(); i++) {
            User user1 =  list.get(i);
            System.out.println(user1);
        }
    }
    @After//在测试方法执行完成之后执行
    public void destroy() throws Exception{
        //提交事务
        session.commit();
        //7.释放资源
        session.close();
        in.close();
    }
}

6.加一个包装类的情况QueryVo.java

package com.domain;
import java.io.Serializable;
public class QueryVo implements Serializable {
    private User user;
    public User getUser() {
        return user;
    }
    public void setUser(User user) {
        this.user = user;
    }
}

总结:主要是IUserDao接口 IUserDao.xml和MybatisTest测试类之间的代码其他的变动不大

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
Java 数据库连接 数据库
MybatisPlus中IService接口有什么用?
MybatisPlus中IService接口有什么用?
|
8天前
|
Java 数据库连接 mybatis
MyBatis中Mapper接口和dao区别是什么?
MyBatis中Mapper接口和dao区别是什么?
|
20天前
|
SQL Java 数据库连接
MyBatis精髓揭秘:Mapper代理实现的黑盒探索
MyBatis精髓揭秘:Mapper代理实现的黑盒探索
22 1
|
20天前
|
SQL Java 数据库连接
MyBatis之魂:探索核心接口SqlSession的神秘力量
MyBatis之魂:探索核心接口SqlSession的神秘力量
26 3
MyBatis之魂:探索核心接口SqlSession的神秘力量
|
22天前
|
XML Java 数据库连接
调用mybatisplus的封装CURD方法出现报错
调用mybatisplus的封装CURD方法出现报错
12 0
|
2月前
|
XML SQL Java
Mybatis接口Mapper内的方法为啥不能重载吗
Mybatis接口Mapper内的方法为啥不能重载吗
20 0
|
2月前
|
Java 数据库连接 mybatis
在SpringBoot集成下,Mybatis的mapper代理对象究竟是如何生成的
在SpringBoot集成下,Mybatis的mapper代理对象究竟是如何生成的
20 0
|
2月前
|
SQL Java 数据库连接
挺详细的spring+springmvc+mybatis配置整合|含源代码
挺详细的spring+springmvc+mybatis配置整合|含源代码
46 1
|
2月前
|
druid Java 数据库连接
Spring Boot3整合MyBatis Plus
Spring Boot3整合MyBatis Plus
46 1
|
3天前
|
XML Java 数据库连接
Spring Boot与MyBatis:整合与实战
【4月更文挑战第29天】在现代的Java Web应用开发中,持久化层框架扮演了至关重要的角色。MyBatis作为一款优秀的持久化框架,被广泛应用于Java开发中。Spring Boot提供了简化开发流程的功能,而与MyBatis的整合也变得更加便捷。
12 0