MyBatis03

2018-10-26  本文已影响0人  BALE_11

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

上一篇下一篇

猜你喜欢

热点阅读