mybaits中每一個實體對象都對應一個Mapper文件,所以在mapper中配置相關的增刪改查語句java
<?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="mapping.studentMapper"> <!-- 指定查詢SQL, parameterType是傳入參數類型,resultType是返回結果--> <select id="getStudent" parameterType="int" resultType="dto.student"> SELECT * FROM student WHERE id=#{id} </select> <!-- 添加 --> <insert id="addStudent" parameterType="dto.student"> INSERT INTO student(name,code) VALUES (#{Name},#{Code}) </insert> <!-- 刪除 --> <delete id="delStudent" parameterType="java.lang.String"> DELETE FROM student WHERE Code=#{_parameter} </delete> <!-- 修改 --> <update id="updateStudent" parameterType="dto.student"> UPDATE student SET name=#{Name} WHERE Code=#{Code} </update> <!-- 查詢所有 --> <select id="getList" resultType="dto.student"> SELECT Id, Name, Code FROM student </select> </mapper>
以上包括基本的增刪改查和查詢集合。其中parameterType是傳入的參數類型,resultType是返回的結果類型,注意單個查詢和查詢全部結果,resultType的值是同樣的sql
@Controller @RequestMapping("/Home") public class HomeController { @Resource(name="applePhone") private IMobilePhone phone; @RequestMapping(value="index") public String Index() { String msg = phone.PhoneBrand(); System.out.print(msg); String resource = "/conf.xml"; //加載mybatis的配置文件 InputStream inputstream =this.getClass().getResourceAsStream(resource); SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputstream); SqlSession session = sessionFactory.openSession(); String statesql= "mapping.studentMapper.getStudent"; //在studentMapper.xml中有命名空間+方法名 Student student= session.selectOne(statesql, 1); System.out.println(student.getName()); return "index"; } @RequestMapping(value="AddStudent") public String AddStudent() { String resource = "/conf.xml"; //加載mybatis的配置文件 InputStream inputstream =this.getClass().getResourceAsStream(resource); SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputstream); SqlSession session = sessionFactory.openSession(); String statesql= "mapping.studentMapper.addStudent";//在studentMapper.xml中有命名空間+方法名 Student student=new Student(); student.setName("PG ONE"); student.setCode("三年二班"); int result = session.insert(statesql,student); session.commit(); session.close(); System.out.println(result); return "index"; } @RequestMapping(value="Delstudent") public String Delstudent() { String resource = "/conf.xml"; //加載mybatis的配置文件 InputStream inputstream =this.getClass().getResourceAsStream(resource); SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputstream); SqlSession session = sessionFactory.openSession(); String statesql= "mapping.studentMapper.delStudent";//在studentMapper.xml中有命名空間+方法名 int result = session.delete(statesql,"00002"); session.commit(); session.close(); System.out.println(result); return "index"; } @RequestMapping(value="Updatestudent") public String Updatestudent() { String resource = "/conf.xml"; //加載mybatis的配置文件 InputStream inputstream =this.getClass().getResourceAsStream(resource); SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputstream); SqlSession session = sessionFactory.openSession(); String statesql= "mapping.studentMapper.updateStudent";//在studentMapper.xml中有命名空間+方法名 student student=new student(); student.setName("GAI"); student.setCode("00002"); int result = session.update(statesql, student); session.commit(); session.close(); System.out.println(result); return "index"; } @RequestMapping(value="List") public String List() { String resource = "/conf.xml"; //加載mybatis的配置文件 InputStream inputstream =this.getClass().getResourceAsStream(resource); SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputstream); SqlSession session = sessionFactory.openSession(); String statesql= "mapping.studentMapper.getList"; //在studentMapper.xml中有命名空間+方法名 java.util.List<student> listResult= session.selectList(statesql); session.commit(); session.close(); for(dto.student item:listResult) { System.out.print(item.getId()+"--"+item.getCode()+"--"+item.getName()); System.out.print("--------------"); } return "index"; } }