MyBatis03

作者: BALE_11 | 来源:发表于2018-10-26 16:28 被阅读0次

    学习了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"

    相关文章

      网友评论

          本文标题:MyBatis03

          本文链接:https://www.haomeiwen.com/subject/fstltqtx.html