学习了3种使用方式
案例链接(包含jar包): https://pan.baidu.com/s/1hykf9d2IEFoEPl8XlMWaqQ 提取码: m342
方式三:
方式三就和前面两个方式有点区别了,个人感觉方式三最方便快捷。
步骤1:新建com.hello.mapper包,mapper是映射器的意思,然后在这个包下新建一个xml文件CarMapper.xlm,具体内容和前面基本一样,但是还是有些地方不同的
<?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">
<!-- namespace 需要与 mapper 接口相对应,需要填写接口的权限名 -->
<mapper namespace="com.hello.mapper.CarMapper">
<!-- 查询全部信息 -->
<!-- 在 MyBatis 中,返回值类型默认是会自动转成集合形式的。 -->
<select id="selectAllCar" parameterType="java.lang.Integer" resultType="com.hello.pojo.Car">
select * from car
</select>
<!-- 按照id查找 -->
<select id="findCarById" parameterType="java.lang.Integer" resultType="com.hello.pojo.Car">
select * from car where id = #{id}
</select>
<!-- 添加 -->
<insert id="addCar" parameterType="com.hello.pojo.Car">
insert into car(name, price) value(#{name}, #{price})
</insert>
<!-- 按照id删除 -->
<delete id="deleteById" parameterType="java.lang.Integer">
delete from car where id = #{id}
</delete>
<!-- 更新 -->
<update id="updateCar" parameterType="com.hello.pojo.Car">
update car set name = #{name}, price = #{price} where id = #{id}
</update>
</mapper>
还需要新建一个相关的接口,名字一定要和xml名字一样也就是CarMapper,并在xml文件中把它们关联起来,也就是上面的<mappernamespace="com.hello.mapper.CarMapper"> ,这个接口里面的方法也是要和CarMapper.xml中的方法名字一样,测试的时候就可以通过调接口里面的方法去调用xml文件里面对应的方法了;然后还要把这个CarMapper.xml文件放到(反射)核心配置文件中也就是SqlMapConfig.xml文件;我们在后面的步骤一一实现。
步骤2:在com.hello.mapper包下新建一个接口,名字为CarMapper,接口里面的方法要和CarMapper.xml中的方法名一样
package com.hello.mapper;
import java.util.List;
import com.hello.pojo.Car;
public interface CarMapper {
//查询全部
public List<Car> selectAllCar();
//按照id查找
public Car findCarById(Integer id);
//添加
public int addCar(Car car);
//按照id删除
public int deleteById(Integer id);
//更新
public int updateCar(Car car);
}
步骤3:配置SqlMapConfig.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"></transactionManager>
<!-- 数据源 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/cz"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<!-- 对象映射-->
<mappers>
<!-- 这个地方映射的不是一个文件了而是一个包,包里面的相关的xml文件(mapper )都会反射到这里,所以所有映射文件都放到同一个mapper包里面,这样就不用我们一个个文件映射了,直接映射一个包,它会自己去找 (大概是这个意思吧 ~)-->
<package name="com.hello.mapper"/>
</mappers>
</configuration>
步骤4:上面的都写好了就可以进行测试了,一样新建一个TestClass测试类,
package com.hello.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
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.junit.Before;
import org.junit.Test;
import com.hello.mapper.CarMapper;
import com.hello.pojo.Car;
public class TestClass {
private SqlSessionFactory factory;
@Before
public void getFactory() throws IOException{
// 1. 加载核心配置文件
InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");
// 2. 获取 SqlSessionFactory
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
factory = builder.build(is);
}
@Test
public void run(){
获取 SqlSession
SqlSession session = factory.openSession();
CarMapper mapper = session.getMapper(CarMapper.class);
//查询全部
/*List<Car> list = mapper.selectAllCar();
System.out.println(list);*/
//按照id查找
/*Car car = mapper.findCarById(2);
System.out.println(car);*/
//添加
/*Car car=new Car("垃圾车",10.0);
int i = mapper.addCar(car);
session.commit();//重要!提交数据!!
System.out.println(i);*/
//按照id删除
/*int i = mapper.deleteById(8);
session.commit();
System.out.println(i);*/
//更新
/*Car car=new Car(6,"粪车",110.0);
int i = mapper.updateCar(car);
session.commit();
System.out.println(i);*/
}
}
上面的CarMapper mapper =session.getMapper(CarMapper.class);中的CarMapper.class指的就是我们建的接口,所以我们就可以通过mapper 调用接口中存在的方法,虽然说接口中的方法是没有实现的,但是xml文件,已经和这个接口关联起来了,所以通过调用接中的方法就可以调用到xml文件中名字一样的方法。就能完成我们的增删改查了。
然后再增加一个小的知识点,就是我们在Car.xml或者是CarMapper.xml中有一个参数类型parameterType和返回值类型resultType,当类型是类类型的时候,我们每次使用的时候需要把类权限路径放上去,比如上面的parameterType="com.hello.pojo.Car",这样子很麻烦,所以文明就可以在SqlMapConfig.xml中配置别名,如下
别名配置好之后我们就可以在后面使用的时候直接使用别名Car了,如parameterType="Car"