基于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日

相关文章

  • IDEA + Maven环境下的SSM框架整合及搭建过程

    以下是“IDEA + Maven环境下的SSM框架整合及搭建过程”的完整攻略: 一、环境准备 首先确认开发环境已经具备以下工具和组件: JDK Tomcat MySQL Maven IDEA 二、创建Maven项目 在IDEA中创建Maven项目,选择Spring Initializr模板,在GroupId中输入自定义的项目组织名称(如com.example…

    Java 2023年5月20日
    00
  • JDBC的扩展知识点总结

    下面我会详细讲解“JDBC的扩展知识点总结”的完整攻略。 JDBC的扩展知识点总结 什么是JDBC Java数据库连接(Java Database Connectivity,简称JDBC)是Java语言中用于执行SQL语句的一组API。通俗地讲,JDBC就是Java语言连接数据库的一个标准规范。使用JDBC,可以使Java程序与任何支持SQL的关系型数据库进…

    Java 2023年5月20日
    00
  • java编程进行动态编译加载代码分享

    一、介绍 动态编译加载(Dynamic Compilation and Loading)是指在运行时将Java源代码进行编译,并将编译后的字节码装载到JVM中,从而实现动态加载代码的效果。这种技术常用于实现插件机制、动态配置等场景。 本文将介绍如何使用Java编程进行动态编译加载代码分享,在介绍具体的实现过程之前,我们先来了解一下Java提供的相关工具和AP…

    Java 2023年5月30日
    00
  • Java读取.properties配置文件的几种方式

    Java读取.properties配置文件的几种方式 1. 使用Properties类来读取配置文件 通过使用Java中自带的Properties类,可以很方便地读取配置文件中的属性值。以下是基本的读取流程: import java.io.FileInputStream; import java.io.FileWriter; import java.io.I…

    Java 2023年5月20日
    00
  • 一步步带你入门Java中File类

    一步步带你入门Java中File类 什么是File类? File类是Java中用来表示文件或目录的类,它可以用来创建、删除、重命名、检查文件或目录是否存在等操作。 如何创建File对象? 我们可以通过以下两种方式来创建File对象: 方法1:使用文件路径字符串创建File对象 File file = new File("path/to/file&q…

    Java 2023年6月1日
    00
  • 引入SpringCloud-gateway报错的解决方案

    接下来我将为你详细讲解“引入SpringCloud Gateway报错的解决方案”的完整攻略。 问题描述 在使用Spring Cloud Gateway框架进行开发时,可能会出现以下报错: org.springframework.beans.factory.BeanCreationException: Error creating bean with nam…

    Java 2023年5月20日
    00
  • Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用

    Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用 什么是Spring Data JPA? Spring Data JPA 是 Spring Data 一个子数据访问项目,该项目基于Spring框架为开发人员提供了一个基于JPA的工具包,方便开发人员使用JPA来访问数据库。 Spring Boot 中使用Spri…

    Java 2023年5月19日
    00
  • Java实用工具之StringJoiner详解

    Java实用工具之StringJoiner详解 在Java中,如果需要将多个字符串连接成一个字符串,可以使用String类中的concat方法或加号+运算符进行字符串拼接。但是当我们需要连接的字符串数量较多,或者需要在每个字符串之间添加一定的分隔符时,这两种方法就显得有些麻烦。 针对这种情况,Java提供了一个实用工具类StringJoiner,它可以轻松地…

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