MyBatis实现增删改查

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

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

1.1 MyBatis环境搭建

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

MyBatis实现增删改查_第1张图片

1.创建工程

1.启动Intellij IDEA开发工具,选择工具栏中的“File”→“New”→“Project”选项,弹出“New Project” 对话框,如图所示。MyBatis实现增删改查_第2张图片

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

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

2.引入相关依赖

MyBatis实现增删改查_第3张图片

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



4.0.0

org.example
example01
1.0-SNAPSHOT
jar

    
        mysql
        mysql-connector-java
        8.0.11
    

    
        org.mybatis
        mybatis
        3.4.5
    
    
        junit
        junit
        4.13
        compile
    

    
        org.slf4j
        slf4j-api
        1.7.20
    
    
        ch.qos.logback
        logback-classic
        1.2.3
    
    
        ch.qos.logback
        logback-core
        1.2.3
    
    
        org.testng
        testng
        RELEASE
        test
    


    8
    8
    UTF-8


 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。




    
    
    
    
    
        
            
            
            
            
                
                
                
                
            
        
    
    
    
        
    

      (这是已经将映射文件路径的配置添加在代码的最后了,用于将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的实现具体代码如下:



    
    

    
    
    
        insert into users(uid,uname, uage, uphone) values (#{uid},#{uname},#{uage},#{uphone});
    
    
    
        update users set uname = #{uname}, uphone = #{uphone},uage = #{uage}  where uid = #{uid};
    
    
    
        delete from users where uid = #{uid};
    

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();
    }
}

具体位置如下:

MyBatis实现增删改查_第4张图片

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

MyBatis实现增删改查_第5张图片

点我下载

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

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

你可能感兴趣的:(mybatis,java,mysql)