MyBatis实现增删改查

      hello大家好,今天根据老师的讲解以及书本的内容实现了对于MyBatis框架中连接数据库,并且对数据库内容实现增删改查的功能。

我将从MyBatis的环境搭建开始,一直到实现基本的增删改查功能。

1.1 MyBatis环境搭建

我将我整个工程的目录放在这里,可以直观的看到文件的创建位置。

1.创建工程

1.启动Intellij IDEA开发工具,选择工具栏中的“File”→“New”→“Project”选项,弹出“New Project” 对话框,如图所示。

 Name是项目名称,Location为文件的存放路径,设置完成后选择create创建工程。

(此界面为22年3月的版本)

2.引入相关依赖

      我们找到pom.xml文件像其中导入MySQL驱动包、JUnit测试包、MyBatis的核心包等相关依赖,具体代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>org.example</groupId>
<artifactId>example01</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
<dependencies>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.11</version>
    </dependency>

    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.4.5</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13</version>
        <scope>compile</scope>
    </dependency>

    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.20</version>
    </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.2.3</version>
    </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.2.3</version>
    </dependency>
    <dependency>
        <groupId>org.testng</groupId>
        <artifactId>testng</artifactId>
        <version>RELEASE</version>
        <scope>test</scope>
    </dependency>
</dependencies>
<properties>
    <maven.compiler.source>8</maven.compiler.source>
    <maven.compiler.target>8</maven.compiler.target>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

</project>

 3.创建数据库

      在MySQL中创建一个名称为 mybatis 的数据库,具体SQL语句如下:

create database mybatis;

4.创建数据库链接配置信息文件

在项目的src/main/resoures目录下创建数据库连接的配置文件,这里将其命名为db.properties,在该文件中配置数据库连接的参数。db.properties文件的具体内容如下所示

mysql.driver=com.mysql.cj.jdbc.Driver
mysql.url=jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC&characterEncoding=utf8&useUnicode=true&useSSL=false
mysql.username=root
mysql.password=123456

      这里的 mysql.username是用户名,mysql.password是密码。

5.创建MyBatis的核心配置文件


      在项目的src/main/resoures目录下创建MyBatis的核心配置文件,该文件主要用于项目的环境配置,如数据库连接相关配置等。核心配置文件可以随意命名,但通常将其命名为mybatis-config.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>
    <!-- 环境配置 -->
    <!-- 加载类路径下的属性文件 -->
    <properties resource="db.properties"/>
    <!--default指定使用哪个environment-->
    <environments default="development">
        <environment id="development">
            <!--p-->
            <transactionManager type="JDBC"/>
            <!-- 数据库连接相关配置 ,db.properties文件中的内容-->
            <dataSource type="POOLED">
                <property name="driver" value="${mysql.driver}"/>
                <property name="url" value="${mysql.url}"/>
                <property name="username" value="${mysql.username}"/>
                <property name="password" value="${mysql.password}"/>
            </dataSource>
        </environment>
    </environments>
    <!-- mapping文件路径配置 -->
    <mappers>
        <mapper resource="com/houjinqiao/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

      (这是已经将映射文件路径的配置添加在代码的最后了,用于将UserMapper.xml映射文件加载到程序中。)

至此,MyBatis的开发环境就搭建完成了。

1.2 MyBatis入门程序

1.数据准备

      在mybatis数据库中创建users表,并在users表中插入几条数据,具体SQL语句如下:

use mybatis;
create table users(
    uid int primary key auto_increment,
    uname varchar(20) not null,
    uage int not null,
    uphone varchar(16)
);
insert into users(uname,uage,uphone) values('梅西',34,'1111111111');
insert into users(uname,uage,uphone) values('罗纳尔多',38,'2222222222');
insert into users(uname,uage,uphone) values('内马尔',31,'3333333333');
insert into users(uname,uage,uphone) values('哈兰德',22,'4444444444');

2.创建POJO实体

      在项目的src/main/java目录下创建com.houjinqiao.pojo包,在com.houjinqiao.pojo包下创建User类、该类用于封装User对象的属性,如下所示:(文件名为User.java)

package com.houjinqiao.pojo;
public class User{

    private int uid;
    private String uname;
    private String uphone;
    private int uage;

    public User() {

    }

    public User(int uid, String uname, String uphone, int uage) {
        this.uid = uid;
        this.uname = uname;
        this.uphone = uphone;
        this.uage = uage;
    }

    public int getUid() {
        return uid;
    }

    public void setUid(int uid) {
        this.uid = uid;
    }

    public String getUname() {
        return uname;
    }

    public void setUname(String uname) {
        this.uname = uname;
    }

    public int getUage() {
        return uage;
    }

    public void setUage(int uage) {
        this.uage = uage;
    }

    public String getUphone() {
        return uphone;
    }

    public void setUphone(String uphone) {
        this.uphone = uphone;
    }

    @Override
    public String toString() {
        return "User{" +
                "uid=" + uid +
                ", uname='" + uname + '\'' +
                ", uphone='" + uphone + '\'' +
                ", uage=" + uage +
                '}';
    }
}

      我们在这里直接创建了空参和有参构造器、set()和 get()以及toString()方法,方便进行等会的增删改查。

3.创建映射文件UserMapper.xml

      在项目的src/main/resoures目录下创建一个mapper文件夹,在mapper文件夹下创建映射文件 UserMapper.xml.该文件主要用于配置SQL语句和Java对象之间的映射,使SQL语句查询出来的数据能够被封装成Java对象。一个项目中可以有多个映射文件,每个实体类都可以有其对应的映射文件。映射文件通常使用POJO实体类名+Mapper命名。例如,User实体类的映射文件名称就为UserMapper.xml。 UserMapper.xml的实现具体代码如下:

<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.houjinqiao.mapper.UserMapper">
    <!--查询操作-->
    <select id="findById" parameterType="int" resultType="com.houjinqiao.pojo.User">
        select * from users where uid = #{uid}
    </select>

    <!--对象中的属性,可以直接取出来-->
    <!--插入操作-->
    <insert id="addUser" parameterType="com.houjinqiao.pojo.User" keyProperty="uid" useGeneratedKeys="true">
        insert into users(uid,uname, uage, uphone) values (#{uid},#{uname},#{uage},#{uphone});
    </insert>
    <!--更新操作-->
    <update id="updateUser" parameterType="com.houjinqiao.pojo.User">
        update users set uname = #{uname}, uphone = #{uphone},uage = #{uage}  where uid = #{uid};
    </update>
    <!--删除操作-->
    <delete id="deleteUser" parameterType="int">
        delete from users where uid = #{uid};
    </delete>
</mapper>

4.编写测试类

在项目的src/test/java目录下创建Test包,在Test包下创建UserTest类,该类主要用于程序测试,代码如下所示:(文件名UserTest.java)

import com.houjinqiao.mapper.UserMapper;
import com.houjinqiao.pojo.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 com.houjinqiao.utils.MyBatisUtils;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import java.io.IOException;
import java.io.Reader;
public class UserTest {
    //没有实现的方法,可以忽略
    /*
    SqlSession sqlSession;
    UserMapper mapper;
    @Before
    public void before() throws IOException {
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    }

    @After
    public void after(){
        sqlSession.commit();
        sqlSession.close();
    }
    */
    //查询测试
    @Test
    public void test01() throws IOException {
       SqlSession sqlSession = MyBatisUtils.getSession();
       User user = sqlSession.selectOne("findById", 1);
       System.out.printf(user.getUname());
       sqlSession.close();
    }
    //通过接口查询测试
    @Test
    public void test02() throws IOException {
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        User user = mapper.findById(1);
        System.out.print(user);
        sqlSession.close();
    }
    //插入测试
    @Test
    public void test03() throws IOException {
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        mapper.addUser(new User(5,"侯晋悄","5555555555",22));
        sqlSession.commit();
        sqlSession.close();
    }
    //更新操作
    @Test
    public void test04() throws IOException {
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        mapper.updateUser(new User(5,"我是梅东","6666666666",34));
        sqlSession.commit();
        sqlSession.close();
    }
    //删除操作
    @Test
    public void test05() throws IOException {
        SqlSession sqlSession = MyBatisUtils.getSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        mapper.deleteUser(5);
        sqlSession.commit();
        sqlSession.close();
    }

}

1.3MyBatis实现增删改查

我们在以上代码的基础上,新建一个UserMapper.java的接口文件

package com.houjinqiao.mapper;
import com.houjinqiao.pojo.User;
public interface UserMapper {
  User findById(int a);
  int addUser(User user);
  int updateUser(User user);
  int deleteUser(int a);
}

在上述测试中,由于每个方法执行时都需要读取配置文件,并根据配置文件的信息构建SqlSessionFactory 对象、创建SqlSession对象、释放资源,这产生了大量的重复代码。为了简化开发,可以将读取配置文件和释放资源的代码封装到一个工具类中,然后通过工具类创建SqISession对象。工具类具体代码如下所示:(文件名为:MyBatisUtils.java)

package com.houjinqiao.utils;
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 java.io.IOException;
import java.io.Reader;

public class MyBatisUtils {
    private static SqlSessionFactory sqlSessionFactory = null;
    static {
        try {
            Reader reader = Resources.getResourceAsReader("mybatis-config.xml");
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    public static SqlSession getSession(){
        return sqlSessionFactory.openSession();
    }
}

具体位置如下:

在创建项目的时候需要下载一些文件,如果下载的缓慢可以下载这个settings文件,将其放在C:\Users\86150\.m2文件夹下,每个人的路径不一样,查看路径的方式为:

点我下载

 之后我们关掉IDEA重新启动就ok了。

最后我们就完成了所有的操作,如果有问题可以留在评论区,我会尽力而为!

  • 8
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学者山羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值