学习了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"
网友评论