基于MyBatis的简单使用(推荐)

下面就给您详细讲解“基于MyBatis的简单使用(推荐)”。

什么是MyBatis?

MyBatis是一款基于Java语言的开源持久层框架,它是面向SQL的框架,并且可以轻松地与各种数据源进行集成。它的主要特点是使得数据持久化开发变得更加容易,开发者只需要编写简单的SQL语句,而且框架还为开发者提供了便捷的ORM操作。

MyBatis的简单使用

下面我们来演示一下如何在Java项目中使用MyBatis。

  1. 首先需要引入MyBatis的相关依赖,常用的有以下五个:
<!--MyBatis核心依赖-->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.7</version>
</dependency>
<!--MyBatis与Spring集成依赖-->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>2.0.6</version>
</dependency>
<!--数据库连接池依赖-->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.2.2</version>
</dependency>
<!--数据库驱动依赖-->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.22</version>
</dependency>
<!--日志依赖-->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.25</version>
</dependency>
  1. 在项目的配置文件中配置数据库连接、MyBatis与Spring的集成、Mapper的扫描等信息。
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
    <property name="url" value="${jdbc.url}" />
    <property name="username" value="${jdbc.username}" />
    <property name="password" value="${jdbc.password}" />
    <property name="initialSize" value="1" />
    <property name="maxActive" value="20" />
    <property name="maxWait" value="60000" />
    <property name="timeBetweenEvictionRunsMillis" value="60000" />
    <property name="minEvictableIdleTimeMillis" value="300000" />
    <property name="validationQuery" value="SELECT 'x'" />
    <property name="testWhileIdle" value="true" />
    <property name="testOnBorrow" value="false" />
    <property name="testOnReturn" value="false" />
    <property name="poolPreparedStatements" value="true" />
    <property name="maxPoolPreparedStatementPerConnectionSize" value="20" />
    <property name="filters" value="mergeStat" />
</bean>

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="typeAliasesPackage" value="com.example.model" />
    <property name="mapperLocations" value="classpath:mapper/*.xml" />
</bean>

<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
    <constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>

<!--扫描MyBatis Mapper-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.example.mapper" />
</bean>
  1. 编写Mapper接口,用于执行SQL语句。
public interface UserMapper {

    @Select("select * from t_user where id = #{id}")
    User selectById(Long id);

    @Select("select * from t_user")
    List<User> selectAll();

    @Insert("insert into t_user(username, password) values(#{username}, #{password})")
    int insert(User user);

    @Update("update t_user set username = #{username}, password = #{password} where id = #{id}")
    int update(User user);

    @Delete("delete from t_user where id = #{id}")
    int deleteById(Long id);

}
  1. 编写Mapper映射文件,用于描述SQL语句的具体内容。
<mapper namespace="com.example.mapper.UserMapper">

    <resultMap id="userMap" type="com.example.model.User">
        <id property="id" column="id" />
        <result property="username" column="username" />
        <result property="password" column="password" />
        <result property="createTime" column="create_time" />
        <result property="updateTime" column="update_time" />
    </resultMap>

    <select id="selectById" resultMap="userMap">
        select * from t_user where id = #{id}
    </select>

    <select id="selectAll" resultMap="userMap">
        select * from t_user
    </select>

    <insert id="insert">
        insert into t_user(username, password) values(#{username}, #{password})
    </insert>

    <update id="update">
        update t_user set username = #{username}, password = #{password} where id = #{id}
    </update>

    <delete id="deleteById">
        delete from t_user where id = #{id}
    </delete>

</mapper>
  1. 编写Service层,调用Mapper接口执行SQL语句,并包装返回的结果。
@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public User selectById(Long id) {
        return userMapper.selectById(id);
    }

    public List<User> selectAll() {
        return userMapper.selectAll();
    }

    public void insert(User user) {
        userMapper.insert(user);
    }

    public void update(User user) {
        userMapper.update(user);
    }

    public void deleteById(Long id) {
        userMapper.deleteById(id);
    }

}
  1. 编写Controller层,对外提供接口。
@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/{id}")
    public User selectById(@PathVariable Long id) {
        return userService.selectById(id);
    }

    @GetMapping("")
    public List<User> selectAll() {
        return userService.selectAll();
    }

    @PostMapping("")
    public void insert(@RequestBody User user) {
        userService.insert(user);
    }

    @PutMapping("")
    public void update(@RequestBody User user) {
        userService.update(user);
    }

    @DeleteMapping("/{id}")
    public void deleteById(@PathVariable Long id) {
        userService.deleteById(id);
    }

}

示例

下面给出基于MyBatis的两个示例。

  1. 查询用户信息

用户信息在t_user表中,包含id, username, password, create_time, update_time五个字段。根据用户id查询其信息。

public interface UserMapper {

    @Select("select * from t_user where id = #{id}")
    User selectById(Long id);

}

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public User selectById(Long id) {
        return userMapper.selectById(id);
    }

}

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/{id}")
    public User selectById(@PathVariable Long id) {
        return userService.selectById(id);
    }

}
  1. 新增用户信息

用户信息需要新增到t_user表中,包含id, username, password, create_time, update_time五个字段。需要通过Spring MVC接收用户提交的数据,并将数据保存到数据库。

public interface UserMapper {

    @Insert("insert into t_user(username, password, create_time, update_time) values(#{username}, #{password}, #{createTime}, #{updateTime})")
    int insert(User user);

}

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public void insert(User user) {
        user.setCreateTime(new Date());
        user.setUpdateTime(new Date());
        userMapper.insert(user);
    }

}

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @PostMapping("")
    public void insert(@RequestBody User user) {
        userService.insert(user);
    }

}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:基于MyBatis的简单使用(推荐) - Python技术站

(0)
上一篇 2023年5月20日
下一篇 2023年5月20日

相关文章

  • SpringSecurity 表单登录的实现

    实现SpringSecurity表单登录需要以下步骤: 导入依赖 需要在项目中导入SpringSecurity相关的依赖包,例如: <dependency> <groupId>org.springframework.security</groupId> <artifactId>spring-security-w…

    Java 2023年5月20日
    00
  • Spring Security实现基于角色的访问控制框架

    Spring Security实现基于角色的访问控制框架 1. 简介 Spring Security是一个功能强大且灵活的框架,用于在Java应用程序中实现身份验证和访问控制。它提供了很多安全性功能,包括身份验证、授权、会话管理、密码管理等。在这篇文章中,我们将了解如何使用Spring Security实现基于角色的访问控制框架。 2. 实现方法 2.1 准…

    Java 2023年6月3日
    00
  • 常见的Java类加载器有哪些?

    我来为你详细讲解一下Java类加载器。 Java类加载器 在Java中,类加载器是用于加载Java类和资源的特殊Java类。Java虚拟机通过它们来动态地加载Java类。Java类加载器是Java技术的核心组成部分,因为它使 Java 的动态实现成为可能。 Java 类加载器是类 Java.lang.ClassLoader 的实例,它负责将类的字节码从文件系…

    Java 2023年5月11日
    00
  • Java异常学习之自定义异常详解

    Java异常学习之自定义异常详解 自定义异常是什么? 在Java的异常体系中,自定义异常指的是用户自己定义的异常类,继承自Throwable或其子类。自定义异常一般用来处理应用程序特别的异常,例如业务逻辑中的特定条件。 如何定义自定义异常? 定义自定义异常需要遵循以下步骤: 创建一个继承自Exception或其子类的Java类; 添加至少一个构造函数,以便在…

    Java 2023年5月27日
    00
  • Java利用多线程模拟银行系统存钱问题

    Java利用多线程模拟银行系统存钱问题的完整攻略 1. 问题分析 假设有两个用户账户,分别在同一时间存钱,我们需要通过Java多线程模拟存钱的过程并确保数据的准确性和安全性。 2. 解决方案 为了确保数据的安全,Java使用了synchronized关键字来实现线程同步,同时也使用了wait()和notify()方法来解决线程的等待和调度问题。 Java中可…

    Java 2023年5月18日
    00
  • mybatis实现对数据的增删查改实例详解

    下面我将详细讲解“mybatis实现对数据的增删查改实例详解”的完整攻略。 1. Mybatis介绍 Mybatis是一种基于Java的数据持久化框架,它通过XML或注解的方式将Java对象映射到数据库中的数据表中,从而实现对数据库的操作。 2. Mybatis的基本使用 2.1 配置文件 Mybatis的配置文件包含了以下几个主要部分: configura…

    Java 2023年5月20日
    00
  • Java基础教程之整数运算

    Java基础教程之整数运算攻略 Java是一种强类型语言,其中包含了整数类型及其运算操作。本文将详细讲解Java基础教程中的整数运算,包括基本概念、运算规则和示例说明。 基本概念 Java中的整数类型主要有四种:byte、short、int和long,对应的存储空间分别为1、2、4和8个字节。整数运算包括加、减、乘、除和取模等操作。 运算规则 Java中的整…

    Java 2023年5月26日
    00
  • Java如何实现读取txt文件内容并生成Word文档

    要实现Java读取txt文件内容并生成Word文档,你需要以下步骤: 步骤一:读取txt文件内容 创建一个File对象,用于表示要读取的txt文件; 创建一个BufferedReader对象,用于读取文件内容; 使用BufferedReader的readLine()方法逐行读取文件内容,把每一行的文本保存到一个字符串变量中。 以下是示例代码: File fi…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部