【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)

准备工作

1. 创建user表
在这里插入图片描述
2. 创建User实体类

public class User {
    private Integer id;
    private String username;
    private String password;

    public User() {
    }

    public User(String username, String password) {
        this.username = username;
        this.password = password;
    }

    public User(Integer id, String username, String password) {
        this.id = id;
        this.username = username;
        this.password = password;
    }

    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 getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

3. 引入mysql驱动

    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.6</version>
    </dependency>

原始JDBC操作

查询

    public static List<User> findAll() throws Exception {
        Class.forName("com.mysql.jdbc.Driver");

        Connection conn = DriverManager.getConnection("jdbc:mysql:///test", "root", "123456");
        String sql = "select * from user";
        PreparedStatement pstmt = conn.prepareStatement(sql);
        ResultSet rs = pstmt.executeQuery();

        List<User> userList = new ArrayList<User>();
        while(rs.next()){
            User user = new User();
            user.setId(rs.getInt("id"));
            user.setUsername(rs.getString("username"));
            user.setPassword(rs.getString("password"));

            userList.add(user);
        }
        rs.close();
        pstmt.close();
        conn.close();
        return userList;
    }

插入

    public static void insertUser(User user) throws Exception{
        Class.forName("com.mysql.jdbc.Driver");

        Connection conn = DriverManager.getConnection("jdbc:mysql:///test", "root", "123456");
        String sql = "insert into user(id,username,password) values(?,?,?)";
        PreparedStatement pstmt = conn.prepareStatement(sql);
        pstmt.setInt(1,user.getId());
        pstmt.setString(2,user.getUsername());
        pstmt.setString(3,user.getPassword());

        int i = pstmt.executeUpdate();
        System.out.println(i);

        pstmt.close();
        conn.close();
    }

mybatis简介与开发步骤

  • mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。
  • mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。
  • 最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbcapi底层访问细节,使我们不用与jdbcapi打交道,就可以完成对数据库的持久化操作。

MyBatis官网地址:http://www.mybatis.org/mybatis-3/

1. 引入mybatis依赖包

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.4.5</version>
    </dependency>

2. 创建表和对应实体类

同上。
在这里插入图片描述

3. 编写映射文件UserMapper.xml

在resources目录下创建文件com/wang/mapper/UserMapper.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">

<mapper namespace="userMapper">
    <select id="findAll" resultType="com.wang.pojo.User">
        select * from user
    </select>
</mapper>

在这里插入图片描述

4. 配置mybatis核心配置文件

在resources目录下创建文件sqlMapConfig.xml. 并添加相应配置

<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql:///test"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>

    <mappers>
        <!-- 映射文件所在位置-->
        <mapper resource="com/wang/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

测试

    public static void main(String[] args) throws IOException {
        //加载核心配置文件
        InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
        //获得sqlSession工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        //获得sqlSession对象
        SqlSession session = sqlSessionFactory.openSession();
        //执行sql语句
        List<User> userList = session.selectList("userMapper.findAll");

        Iterator<User> iterator = userList.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }

        session.close();
    }

在这里插入图片描述

mybatis的增删改查

插入操作

1 . 映射文件加入

    <insert id="add" parameterType="com.wang.pojo.User">
        insert into user(id,username,password) values(#{id},#{username},#{password})
    </insert>

2 . 测试

    @Test
    public void add() throws Exception{
        //加载核心配置文件
        InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
        //获得sqlSession工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        //获得sqlSession对象
        SqlSession session = sqlSessionFactory.openSession();
        //执行sql语句
        int insert = session.insert("userMapper.add",new User("Curry","30303030"));
        System.out.println(insert);

        session.commit();
        session.close();
    }

3 . 注意

  • 插入语句使用insert标签
  • 在映射文件中使用parameterType属性指定要插入的数据类型
  • Sql语句中使用#{实体属性名}方式引用实体中的属性值
  • 插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);
  • 插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

删除操作

1 . 映射文件加入

    <delete id="delete" parameterType="java.lang.Integer">
        delete from user where id=#{id}
    </delete>

2 . 测试

   @Test
   public void delete() throws Exception{
       //加载核心配置文件
       InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
       //获得sqlSession工厂对象
       SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
       //获得sqlSession对象
       SqlSession session = sqlSessionFactory.openSession();
       //执行sql语句
       int delete = session.delete("userMapper.delete",1); //删除id=1的user
       System.out.println(delete);

       session.commit();
       session.close();
   }

3 . 注意

  • 删除语句使用delete标签
  • Sql语句中使用#{任意字符串}方式引用传递的单个参数
  • 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

修改操作

1 . 映射文件加入

    <update id="update" parameterType="com.wang.pojo.User">
        update user set username=#{username},password=#{password} where id=#{id}
    </update>

2 . 测试

   @Test
   public void update() throws Exception{
       //加载核心配置文件
       InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
       //获得sqlSession工厂对象
       SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
       //获得sqlSession对象
       SqlSession session = sqlSessionFactory.openSession();
       //执行sql语句
       int update = session.update("userMapper.update",new User(2,"科比","24-8")); //删除id=2的user
       System.out.println(update);

       session.commit();
       session.close();
   }

3 . 注意

  • 修改语句使用update标签
  • 修改操作使用的API是sqlSession.update(“命名空间.id”,实体对象);

查询操作

见上述开发步骤,这里不再重复。

核心配置文件常用标签

在这里插入图片描述

1 . environments标签
在这里插入图片描述
事务管理类型有两种
1 . JDBC:使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
2 . MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false 来阻止它默认的关闭行为。

数据源类型有三种:
1 . UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
2 . POOLED:这种数据源的实现利用“池”的概念将JDBC 连接对象组织起来。
3 . JNDI:这个数据源的实现是为了能在如EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDI 上下文的引用。

2 . mapper标签
mapper标签用于加载映射文件。
加载方式有如下几种:

  • 使用相对于类路径的资源引用,例如:

<mapper resource="com/wang/mapper/UserMapper.xml"/>

  • 使用完全限定资源定位符(URL),例如:

<mapper url="file:///mapper/UserMapper.xml"/>

  • 使用映射器接口实现类的完全限定类名,例如:

<mapper class="com.wang.mapper.UserMapper"/>

  • 将包内的映射器接口实现全部注册为映射器,例如:

<package name="com.wang.mapper"/>

3. properties标签
properties标签加载额外配置的properties文件,例如将数据源的配置信息单独抽取成一个properties文件。
在这里插入图片描述

在这里插入图片描述

4 . typeAliases标签
在映射文件中为SQL参数类型或者返回类型的时候,需要配置全包名,这就比较烦人。
在这里插入图片描述
这是就可以使用typeAliases标签,为Java 类型设置一个短的名字。

    <typeAliases>
        <typeAlias type="com.wang.pojo.User" alias="user"/>
    </typeAliases>

在这里插入图片描述

mybatis框架已经为我们设置好的一些常用的类型的别名

在这里插入图片描述

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
10天前
|
前端开发 Oracle 关系型数据库
关于使用SSM+JSP开发时setter、getter隐式调用问题的小结
本文主要分享了在使用SSM+JSP进行网站开发时,因忽视setter、getter的隐式调用问题而导致的常见bug及其解决方法。详细介绍了setter和getter的隐式调用时机,并给出了具体示例,帮助开发者避免类似问题。
36 11
|
18天前
|
SQL Java 数据库连接
MyBatis-Plus快速入门:从安装到第一个Demo
本文将带你从零开始,快速入门 MyBatis-Plus。我们将首先介绍如何安装和配置 MyBatis-Plus,然后通过一个简单的示例演示如何使用它进行数据操作。无论你是 MyBatis 的新手还是希望提升开发效率的老手,本文都将为你提供清晰的指导和实用的技巧。
104 0
MyBatis-Plus快速入门:从安装到第一个Demo
|
5月前
|
XML Java 数据库连接
MyBatis入门——MyBatis XML配置文件(3)
MyBatis入门——MyBatis XML配置文件(3)
71 6
|
2月前
|
Java 数据库连接 数据库
SpringBoot 整合jdbc和mybatis
本文详细介绍了如何在SpringBoot项目中整合JDBC与MyBatis,并提供了具体的配置步骤和示例代码。首先,通过创建用户实体类和数据库表来准备基础环境;接着,配置Maven依赖、数据库连接及属性;最后,分别展示了JDBC与MyBatis的集成方法及其基本操作,包括增删查改等功能的实现。适合初学者快速入门。
SpringBoot 整合jdbc和mybatis
|
2月前
|
SQL 存储 Java
原生JDBC简单实现Mybatis核心功能
本文介绍了在Vertx项目中使用Tdengine时,因缺乏异步JDBC驱动而采用同步驱动结合`vertx.executeBlocking`实现异步查询的方法。文中详细描述了自行开发的一个简易JDBC工具,该工具实现了SQL参数绑定与返回值映射至实体类的功能,简化了原生JDBC的繁琐操作。通过具体示例展示了其实现过程及代码细节,并与原生JDBC进行了对比,突显了其便捷性和实用性。
|
1月前
|
SQL Java 数据库连接
JDBC存在什么问题?MyBatis是如何解决的?
本文详细探讨了JDBC(Java Database Connectivity)在实际应用中存在的问题,如代码繁琐、资源管理困难、SQL语句硬编码、缺乏对象映射及事务管理和缓存支持不足等。JDBC的核心组件包括`DriverManager`、`Connection`、`Statement`、`ResultSet`和`SQLException`。为了解决这些问题,文章介绍了MyBatis框架的优势,如简化代码编写、自动资源管理、SQL与代码分离、支持对象关系映射(ORM)、简化事务管理和内置缓存机制。通过具体示例展示了MyBatis如何优化数据库操作。理解JDBC的原理有助于更好地掌握ORM框架。
21 0
|
3月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
47 1
|
5月前
|
SQL XML Java
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
71 3
|
5月前
|
Java 数据库连接 API
后端开发之用Mybatis简化JDBC的开发快速入门2024及数据库连接池技术和lombok工具详解
后端开发之用Mybatis简化JDBC的开发快速入门2024及数据库连接池技术和lombok工具详解
63 3
|
5月前
|
前端开发
杨校老师之基于SSM开发的校园点餐配送系统
杨校老师之基于SSM开发的校园点餐配送系统
60 0
杨校老师之基于SSM开发的校园点餐配送系统