hello大家好,今天根据老师的讲解以及书本的内容实现了对于MyBatis框架中连接数据库,并且对数据库内容实现增删改查的功能。
我将从MyBatis的环境搭建开始,一直到实现基本的增删改查功能。
我将我整个工程的目录放在这里,可以直观的看到文件的创建位置。
1.启动Intellij IDEA开发工具,选择工具栏中的“File”→“New”→“Project”选项,弹出“New Project” 对话框,如图所示。
Name是项目名称,Location为文件的存放路径,设置完成后选择create创建工程。
(此界面为22年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
在MySQL中创建一个名称为 mybatis 的数据库,具体SQL语句如下:
create database mybatis;
在项目的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是密码。
在项目的src/main/resoures目录下创建MyBatis的核心配置文件,该文件主要用于项目的环境配置,如数据库连接相关配置等。核心配置文件可以随意命名,但通常将其命名为mybatis-config.xml。
(这是已经将映射文件路径的配置添加在代码的最后了,用于将UserMapper.xml映射文件加载到程序中。)
至此,MyBatis的开发环境就搭建完成了。
在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');
在项目的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()方法,方便进行等会的增删改查。
在项目的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};
在项目的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();
}
}
我们在以上代码的基础上,新建一个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了。
最后我们就完成了所有的操作,如果有问题可以留在评论区,我会尽力而为!