Mybatis入门-基于注解实现单表、多表的增删改查

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mybatis入门-基于注解实现单表、多表的增删改查


Mybatis入门-基于xml配置实现单表的增删改查


配置步骤

1.引入Mybatis的jar包


2.编写实体类与DAO接口


3.添加主配置文件(配置mysql环境,事务类型,数据源,连接数据库的基本信息,映射文件的位置)


4.使用mybatis中的注解


5.使用mybatis框架


使用步骤

1.读取配置文件,可使用mybatis封装的Resources类。


2.创建SQLSessionFactory工厂


3.使用工厂生产SQLsession对象


4.使用SQLSession创建DAO接口的代理对象


5.使用代理对象执行方法


6.提交事务,释放资源


实体类

/**
 * @Author: Promsing
 * @Date: 2021/4/5 - 9:08
 * @Description: User类、Account类
 * @version: 1.0
 */
public class User implements Serializable {
    private Integer id;
    private String username;
    private String address;
    private String sex;
    private Date birthday;
    //一对多关系映射 一个用户对应多个账户
    private List<Account> accounts;
    public List<Account> getAccounts() {
        return accounts;
    }
    public void setAccounts(List<Account> account) {
        this.accounts = account;
    }
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", address='" + address + '\'' +
                ", sex='" + sex + '\'' +
                ", birthday=" + 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;
    }
}
public class Account implements Serializable {
    private Integer id;
    private Integer uid;
    private Double money;
    //多对一 每个账户只能属于一个用户
    private User user;
    public User getUser() {
        return user;
    }
    public void setUser(User user) {
        this.user = user;
    }
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public Integer getUid() {
        return uid;
    }
    public void setUid(Integer uid) {
        this.uid = uid;
    }
    public Double getMoney() {
        return money;
    }
    public void setMoney(Double money) {
        this.money = money;
    }
    @Override
    public String toString() {
        return "Account{" +
                "id=" + id +
                ", uid=" + uid +
                ", money=" + money +
                '}';
    }
}

DAO接口+注解

/**
 * @Author: Promsing
 * @Date: 2021/4/5 - 9:10
 * @Description: mybatis:基于注解开发
 * @version: 1.0
 */
public interface IUserDao {
    /**
     * 查询所有用户
     * @return
     */
    @Select("select * from User")
    //当实体类属性与MySQL列名不一致时
    //id属性可被其他方法引用---  @ResultMap("userMap")
    @Results(id="userMap", value = {
            //主键为true    库中列名     类中属性
            @Result(id=true,column = "id",property = "id"),
            @Result(column = "username",property = "username"),
            @Result(column = "birthday",property = "birthday"),
            @Result(column = "sex",property = "sex"),
            @Result(column = "address",property = "address"),
            //关系为一对多 延迟加载
            @Result(column = "id",property = "accounts",
                    many = @Many(
                            select = "com.dynamic_annotation_real.dao.IAccountDao.findAccountByUid",
                            fetchType = FetchType.LAZY))
    })
    List<User> findAll();
    /**
     * 查询一个
     * @param i
     * @return
     */
    @Select("select * from user where id=#{id}")
    User findById(Integer i);
    /**
     * 根据名称模糊查询
     * @param name
     * @return
     */
    @Select("select * from user where username like #{name}")
    List<User> findUserByName(String name);
    /**
     * 保存操作
     * @param user
     */
    @Insert("insert into user(username,address,sex,birthday) values(#{username},#{address},#{sex},#{birthday})")
    void saveUser(User user);
    /**
     * 更新操作
     * @param user
     */
    @Update("update user set username=#{username},sex=#{sex},birthday=#{birthday},address=#{address} where id=#{id}")
    void updateUser(User user);
    /**
     * 删除用户
     * @param userid
     */
    @Delete("delete from User where id=#{id}")
    void deleteUser(Integer userid);
    /**
     * 查询总行数
     * @return
     */
    @Select("select count(id) from user")
    int findTotalUser();
}
public interface IAccountDao {
    /**
     * 查询所有
     * @return
     */
    @Select("select * from Account")
    @Results(id="accountMap",value = {
            @Result(id=true,column = "id",property = "id"),
            @Result(column = "uid",property = "uid"),
            @Result(column = "money",property = "money"),
            //配置立即加载
            @Result(property ="user", column = "uid",
                    one = @One(
                            select = "com.dynamic_annotation_real.dao.IUserDao.findById",
                            fetchType = FetchType.EAGER)),
    })
    List<Account> findAll();
    /**
     * 根据用户id查询账户信息
     * @param userId
     * @return
     */
    @Select("select * from Account where uid=#{userId}")
    List<Account> findAccountByUid(Integer userId);
}

主配置文件

<?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">
<!--myBatis的主配置文件 -->
<configuration>
    <!--配置别名-->
    <typeAliases>
        <package name="com.dynamic_annotation_real.domain"/>
    </typeAliases>
    <!--配置环境-->
    <environments default="mysql">
        <!--配置mysql环境-->
        <environment id="mysql">
            <!--配置事务的类型-->
            <transactionManager type="JDBC"></transactionManager>
            <!--配置数据源(连接池)-->
            <dataSource type="POOLED">
                <!--配置连接数据库的基本信息-->
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/eesy"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    <!--注解开发-->
    <mappers>
       <package name="com.dynamic_annotation_real.dao"></package>
    </mappers>
    <!--映射文件 注解方式(使用注解就要删除源配置文件)-->
   <!-- <mappers>
        <mapper class="com.dynamic_basics.dao.IUserDao"></mapper>
    </mappers>-->
</configuration>

测试类

public class AnnotationTest {
    private SqlSession sqlSession;
    private InputStream in;
    private IUserDao userDao;
    private IAccountDao accountDao;
    @Before
    public void init() throws Exception{
        //1.读取配置文件
        in= Resources.getResourceAsStream("SqlMapConfig_realanno.xml");
        //2.创建SqlSessionFactory工程
        SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(in);
        //3.通过工厂创建SqlSession
         sqlSession = factory.openSession();
         //4.代理模式增强方法
        userDao = sqlSession.getMapper(IUserDao.class);
        accountDao = sqlSession.getMapper(IAccountDao.class);
    }
    @After
    public void destroy()  throws Exception{
        sqlSession.commit();
        sqlSession.close();
        in.close();
    }
    @Test
    public void testFindAll(){
        List users = userDao.findAll();
        for (User user : users) {
            System.out.println("---每个用户的账户信息---");
            System.out.println(user);
            System.out.println(user.getAccounts());
        }
    }
    @Test
    public void testSaveUser(){
       User user=new User();
       user.setUsername("alibaba");
       user.setAddress("壹号院");
       user.setSex("女");
       user.setBirthday(new Date());
       userDao.saveUser(user);
    }
    @Test
    public void testUpdateUser(){
        User user=new User();
        user.setUsername("CSDN");
        user.setAddress("北京");
        user.setSex("男");
        user.setBirthday(new Date());
        user.setId(45);
        userDao.updateUser(user);
    }
    @Test
    public void testDelete(){
        userDao.deleteUser(53);
    }
    @Test
    public void testFindOne(){
        User user = userDao.findById(52);
        System.out.println(user);
        //默认开启一级缓存
        User user2 = userDao.findById(52);
        System.out.println(user2);
        System.out.println(user==user2);
    }
    @Test
    public void testFindByName(){
        List users = userDao.findUserByName("%s%");
        for (User user : users) {
            System.out.println(user);
        }
    }
    @Test
    public void testFindTotal(){
        int totalUser = userDao.findTotalUser();
        System.out.println(totalUser);
    }
    /*注解一对一,一对多*/
    @Test
    public void testAccountFindAll(){
        List accounts = accountDao.findAll();
        for (Account account : accounts) {
            System.out.println("---每个账户信息---");
            System.out.println(account);
            System.out.println(account.getUser());
        }
    }
}

总结mybatis注解

@Insert:实现新增


@Update:实现更新


@Delete:实现删除


@Select:实现查询


@Result:实现结果集封装


@Results:可以与@Result一起使用,封装多个结果集


@ResultMap:实现引用@Results定义的封装


@One:实现一对一结果集封装


@Many:实现一对多结果集封装



相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
18天前
|
SQL 缓存 Java
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
52 5
|
18天前
|
Java 数据库连接 mybatis
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
39 3
|
24天前
|
SQL 存储 数据库
深入理解@TableField注解的使用-MybatisPlus教程
`@TableField`注解在MyBatis-Plus中是一个非常灵活和强大的工具,能够帮助开发者精细控制实体类与数据库表字段之间的映射关系。通过合理使用 `@TableField`注解,可以实现字段名称映射、自动填充、条件查询以及自定义类型处理等高级功能。这些功能在实际开发中,可以显著提高代码的可读性和维护性。如果需要进一步优化和管理你的MyBatis-Plus应用程
105 3
|
23天前
|
Java 数据库连接 mybatis
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
41 1
|
1月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
113 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
1月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
55 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
1月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
319 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
1月前
|
SQL Java 数据库连接
mybatis使用二:springboot 整合 mybatis,创建开发环境
这篇文章介绍了如何在SpringBoot项目中整合Mybatis和MybatisGenerator,包括添加依赖、配置数据源、修改启动主类、编写Java代码,以及使用Postman进行接口测试。
17 0
mybatis使用二:springboot 整合 mybatis,创建开发环境
|
1月前
|
Java 数据库连接 API
springBoot:后端解决跨域&Mybatis-Plus&SwaggerUI&代码生成器 (四)
本文介绍了后端解决跨域问题的方法及Mybatis-Plus的配置与使用。首先通过创建`CorsConfig`类并设置相关参数来实现跨域请求处理。接着,详细描述了如何引入Mybatis-Plus插件,包括配置`MybatisPlusConfig`类、定义Mapper接口以及Service层。此外,还展示了如何配置分页查询功能,并引入SwaggerUI进行API文档生成。最后,提供了代码生成器的配置示例,帮助快速生成项目所需的基础代码。