实验内容
实验内容:创建Mybatis并使用xml的方式配置一个findById函数并输出对应的数据库数据
安装Mysql(自行安装)并创建库mybatis
创建表 user
(表中参数有些在本次实验中用不上,所以不贴代码)
在表中随意加入数据
创建Java项目(如图版本为2023.3.4版)
直接使用新建项目即可,其他某马中的教程使用的低版本有创建maven的
高版本中的Maven Archetype 暂时用不上
加入MAVEN依赖
更改pom.xml
建议只复制dependencies
<?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>MybatisTest</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.26</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.14</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy</artifactId>
<version>3.0.9</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
创建文件 db.properties
位置在src/main/resources里面
代码如下:
# 选择驱动 加cj是mysql8以上的驱动 mysql5则用com.mysql.jdbc.Driver
mysql.driver=com.mysql.cj.jdbc.Driver
# 改成你自己数据库的账号密码
mysql.username=root
mysql.password=root
# 数据库连接地址
mysql.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai&useSSL=false
创建User
位置在src/main/java/org/example/pojo(无则创建)
package org.example.pojo;
public class User {
// 属性写完就可以全部生成了 右键生成getter setter toString
private int id;
private String name;
private int age;
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
'}';
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
创建mybatis-config.xml
位置在src/main/resources里面
<?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>
<!-- 引入外部db.properties文件-->
<properties resource="db.properties"/>
<!-- 定义了两个环境(environment),默认为"development"环境 -->
<environments default="development">
<!-- "development"环境的配置 -->
<environment id="development">
<!-- 使用JDBC事务管理器 -->
<transactionManager type="JDBC"/>
<!-- 配置一个类型为"POOLED"的数据源 -->
<dataSource type="POOLED">
<!-- 数据源的驱动类名 -->
<property name="driver" value="${mysql.driver}"/>
<!-- 数据源的URL -->
<property name="url" value="${mysql.url}"/>
<!-- 数据源的用户名 -->
<property name="username" value="${mysql.username}"/>
<!-- 数据源的密码 -->
<property name="password" value="${mysql.password}"/>
</dataSource>
</environment>
</environments>
<!-- 引入名为"mapper/UserMapper.xml"的映射器文件 -->
<mappers>
<mapper resource="mapper/UserMapper.xml"/>
</mappers>
</configuration>
创建UserMapper.xml
习惯上在src/main/resources/mapper(无则新建)里面创建
<?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="org.example.pojo.User">
<!-- 根据用户ID查询用户信息 -->
<select id="findById"
parameterType="int"
resultType="org.example.pojo.User">
select * from user where id = #{id}
</select>
</mapper>
最后创建测试用例UserMapperTest(起名随意)
位置在这src/test/java
文件中名字与自己创建的文件对应
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 org.example.pojo.User;
import org.junit.Test;
import java.io.InputStream;
import java.util.List;
public class UserMapperTest {
@Test
public void findById() throws Exception {
//1.获取核心配置文件
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
//2.创建sqLsessionFactory 工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.创建sqLsession对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//4.执行sqL语句
User user = sqlSession.selectOne("org.example.pojo.User.findById",2);
System.out.println(user);
//5.释放资源
sqlSession.close();
}
}
运行结果
BUG列表
配置阿里云的maven镜像
报错:只有在任务处于完成状态(RanToCompletion、Faulted 或 Canceled)时才能释放它。 - 哔哩哔哩
解决Unresolve plugin:‘org.apache_unresolved plugin: 'org.apache.maven.plugins:maven-CSDN博客
尝试启动 MySQL80 服务,但未能成功启动,提示“只有在任务处于完成状态时才能释放
在服务中找到Mysql80服务然后右键启动