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了。
最后我们就完成了所有的操作,如果有问题可以留在评论区,我会尽力而为!