MyBatis框架的入门案例
MyBatis框架的入门案例
资源地址:https://download.csdn.net/download/weixin_41957626/87531373
1.MyBatis的配置
环境:基于maven的结构
1.1目录结构
1.2依赖包
<dependencies>
<!--mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<!--mysql驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.12</version>
</dependency>
<!--junit-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
</dependency>
<!--log4j-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.12</version>
</dependency>
<!-- 简化属性开发-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>RELEASE</version>
<scope>compile</scope>
</dependency>
</dependencies>
1.3配置文件代码
1.主要分为log4j的配置和MyBatis的配置文件的配置
SqlMapConfig.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<!--nybatis的配置文件
设置数据源等信息
-->
<configuration><!--配置mysql环境-->
<!-- 默认采用development环境的配置--><environments default="development">
<!-- 开发环境,id的值随便写--><environment id="development"><!--配置事务类型交给JDBC处理,还有别的--><transactionManager type="JDBC"></transactionManager><!--数据源POOLED设置使用连接池UNPOOLED表示不使用连接池--><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://127.0.0.1:3306/xxxx?userSSL=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!--注册映射文件,注意地址--><mappers>
<!-- 注意地址的写法-->
<!-- 采用的不是在resource目录下配置的 <mapper resource="cn/lxz/mapper/xml/UserMapper.xml"></mapper>-->
<!-- 采用的是在resource目录下配置的--><mapper resource="mappers/UserMapper.xml"></mapper></mappers></configuration>
log4j配置
log4j.rootLogger=debug, stdout, Rlog4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%nlog4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.loglog4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=5log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
1.4实体和mapper代码
1.4.1实体代码
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Serializable {
private Integer id;
private String name;}
1.4.2mapper代码
public interface UserMapper {public List<User> findAllUsers();public int addUser(User user);public int deleteUserById(User user);public int updateUser(User user);}
1.4.3mapper映射文件代码
<?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="cn.lxz.mapper.UserMapper">
<!--sql--> <!-- select insert update delete -->
<insert id="addUser">
insert into user(name) values (#{name})
</insert>
<update id="updateUser">
update user set name=#{name} where id=#{id}
</update>
<delete id="deleteUserById">
delete from user where id=#{id}
</delete>
<select id="findAllUsers" resultType="cn.lxz.domain.User">
select * from user;
</select></mapper>
1.4.4注意事项
映射文件注意事项:
映射文件中的id属性是对应的持久层接口中的方法名
映射文件要和接口名称相同。
映射文件要和接口的目录结构相同。
映射文件中namespace属性要写接口的全名。
映射文件中标签的id属性是接口方法的方法名。
映射文件中标签的resultType属性是接口方法的返回值类型。
映射文件中标签的parameterType属性是接口方法的参数类型。
映射文件中resultType、parameterType属性要写全类名,如果是集合类型,则写其泛型的全类名。
1.5测试类
1.5.1测试代码
需要学会使用Junit单元测试的方法
掌掌握builder,factory再session,再去加载mapper再去执行相关的操作
1.查询所有的用户信息
public class UserMapperTest {@Testpublic void findAll() throws IOException {//读取核心配置文件InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");//创建builder对象SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();//factory对象SqlSessionFactory factory = builder.build(inputStream);//创建sessionSqlSession session = factory.openSession();//SqlSession对象获取代理对象UserMapper mapper = session.getMapper(UserMapper.class);//代理对象执行方法List<User> all = mapper.findAllUsers();for (User u : all){System.out.println(u);}//关闭资源
session.close();
inputStream.close();}
}
2.增加用户的信息
@Test
public void addUser() throws Exception{
//读取核心配置文件
InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");
//创建builder对象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
//factory对象
SqlSessionFactory factory = builder.build(inputStream);
//创建session
SqlSession session = factory.openSession();
//SqlSession对象获取代理对象
UserMapper mapper = session.getMapper(UserMapper.class);
//================================================================
mapper.addUser(new User(null,"王五"));
//================================================================
//关闭资源
session.close();
inputStream.close();
}
1.5.2测试截图
- 查询全部的信息
- 增加