1.首先在数据库创建一个数据库 Mybatis
创建一个测试表:Mybatis_employee
里面的字段和数据如下:
2.创建一个 Mybatis1.0 项目
1)创建一个对应数据库对象的 javaBean->Employee.java;
package com.Mybatis.entity;
public class Employee {
private int Id;
private String Last_Name;
private char Gender;
private String Email;
public int getId() {
return Id;
}
public void setId(int id) {
Id = id;
}
public String getLast_Name() {
return Last_Name;
}
public void setLast_Name(String last_Name) {
Last_Name = last_Name;
}
public char getGender() {
return Gender;
}
public void setGender(char gender) {
Gender = gender;
}
public String getEmail() {
return Email;
}
public void setEmail(String email) {
Email = email;
}
@Override
public String toString() {
return "Employee [Id=" + Id + ", Last_Name=" + Last_Name + ", Gender=" + Gender + ", Email=" + Email + "]";
}
}
3.创建一个 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>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
<property name="username" value="Student" />
<property name="password" value="a147896325" />
</dataSource>
</environment>
</environments>
<!-- 一定要把我们的sql映射文件(EmployeeMapping.xml)注入到全局配置文件中(Mybatis-config.xml) -->
<mappers>
<mapper resource="EmployeeMapping.xml" />
</mappers>
</configuration>
4.配置 Sql 映射文件,文件名为 EmployeeMapping.xml
<?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.mybatis.EmployeegMapper">
<!--
namespace:名称空间
id:唯一标识符
resultType:返回值类型
#{id}:从传递过来的参数取出id值
-->
<select id="selectEmp" resultType="com.Mybatis.entity.Employee">
select * from Mybatis_Employee where id = #{id}
</select>
</mapper>
5.创建测试类 Mybatis_Test.java
package com.Mybatis.JUnit.test;
import static org.junit.Assert.*;
import java.io.IOException;
import java.io.InputStream;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.*;
import org.junit.Test;
import com.Mybatis.entity.Employee;
public class Mybatis_Test {
/*
* 1.根据XMl配置文件(全局配置文件) 创建一个SqlSessionFactory 对象
* 有数据源一些运行环境信息
* 2.Sql映射文件;配置了每一个Sql,以及Sql的封装规则
* 3.将Sql映射文件注册在全局配置文件中
* 4.写代码
* 1).根据全局配置文件得到SqlsessionFactory
* 2).使用SqlSession工程,获取到SqlSession对象使用它来执行增删改查
* 一个SqlSession就是代表和数据库的一次会话,用完关闭
* */
@Test
public void test() throws IOException {
String resource = "Mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//2.获取SqlSession实例,能直接执行已经映射的Sql语句
SqlSession openSession = sqlSessionFactory.openSession();
try{
Employee employee = openSession.selectOne("org.mybatis.EmployeegMapper.selectEmp", 1);
System.out.println(employee);
}finally{
openSession.close();
}
}
}
6.测试结果
* 本次遇到的问题:导入 jar 包的时候发现无法导入 org.apache.ibatis.io.Resources
然后发现了个低级错误,我把 lib 文件夹创建在类路径下了,需要在 WEB-INF 下创建
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于