前提:需要的包log4j.jar,mybatis-3.4.1.jar,mysql-connector-java-5.1.37-bin.jar

1.基本类

员工类

package com.hand.mybatis.bean;

public class Employee {
    
    private Integer eId;
    private String eName;
    private Integer gender;
    private String email;
    private Department dept;
    public Employee() {
        super();
    }
    public Employee(Integer eId,String eName, Integer gender, String email) {
        super();
        this.eId=eId;
        this.eName = eName;
        this.gender = gender;
        this.email = email;
    }
    public Integer geteId() {
        return eId;
    }
    public void seteId(Integer eId) {
        this.eId = eId;
    }
   
    public String getEName() {
        return eName;
    }
    public void setEname(String ename) {
        this.eName = ename;
    }
    public Integer getGender() {
        return gender;
    }
    public void setGender(Integer gender) {
        this.gender = gender;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    
    
    
    public Department getDept() {
        return dept;
    }

public void setDept(Department dept) {
        this.dept = dept;
    }
    @Override
    public String toString() {
        return "Employee [eId=" + eId + ", ename=" + eName + ", gender=" + gender + ", email=" + email + "]";
    }

}

部门类

package com.hand.mybatis.bean;
import java.util.List;

public class Department {
    private Integer id;
    private String departName;
    private List<Employee> empList;
    
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getDepartName() {
        return departName;
    }
    public void setDepartName(String departName) {
        this.departName = departName;
    }
    
    public List<Employee> getEmpList() {
        return empList;
    }
    public void setEmpList(List<Employee> empList) {
        this.empList = empList;
    }
   
    @Override
    public String toString() {
        return "Department [id=" + id + ", departName=" + departName + "]";
    }
   
}

EmployeeMapper.java 接口

package com.hand.mybatis.dao;
import java.util.List;
import java.util.Map;

import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Param;
import com.hand.mybatis.bean.Employee;

public interface EmployeeMapper {
    
    Employee selectEmployee(Integer eid);
    
    int addEmp(Employee employee);
    
    Boolean updateEmp(Employee employee);
    
    int deleteEmpById(Integer id);
    
    //传入多个参数的情况
    //Employee getEmp(@Param("id") Integer id,@Param("ename") String ename);
    
    //传入多个参数的情况(map)
    Employee getEmp(Map<String, Object> map);
    
    //集合List
    List<Employee> getEmpByeNameLike(String ename);
    
    //返回一条记录的map;key就是列名,值是对应的值
    Map<String, Object> getEmpByIdReturnMap(Integer id);
    
    //多条记录封装一个map:Map<Integer,Employee>:键是这条记录的主键,值是记录封装后的javaBean
    //告诉mybatis封装这个map的时候使用哪个属性作为map的key
    /*@MapKey("eId")
     Map<Integer, Employee> getEmpByLastNameLikeReturnMap(String ename);*/
    @MapKey("eName")
    Map<String, Employee> getEmpByLastNameLikeReturnMap(String ename);
   
}

EmployeeMapper.xml映射文件

<?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="com.hand.mybatis.dao.EmployeeMapper">

<!-- mapper接口 public interface EmployeeMapper {} -->
 <!--  查找
  Employee selectEmployee(Integer eid); -->
 <select id="selectEmployee" resultType="com.hand.mybatis.bean.Employee">
   SELECT * FROM emp WHERE eid=#{eid}
 </select>
 
 <!--添加  
 int addEmp(Employee employee);-->
 <insert id="addEmp" useGeneratedKeys="true" keyProperty="eId">  //使用 useGeneratedKeys="true" keyProperty="eId" 调用接口时,可以获得主键eid
    insert into emp(ename,gender,email)
    VALUES(#{eName},#{gender},#{email})
 </insert>
 
 <!-- 更新
  Boolean updateEmp(Employee employee); -->  //返回值类型Boolen int void long 都行
 <update id="updateEmp">
   UPDATE emp SET ename=#{eName},gender=#{gender},email=#{email}
   WHERE eid=#{eId}
 </update>
 
 <!--删除
  int deleteEmpById(Integer id); -->
 <delete id="deleteEmpById">
    DELETE FROM emp WHERE eid=#{eid}
 </delete>
 
 <!--   
     //传入多个参数的情况
    //Employee getEmp(@Param("id") Integer id,@Param("ename") String ename); //使用@Param()注解
    
    //传入多个参数的情况(map)  
    Employee getEmp(Map<String, Object> map); --> //调用接口时,需要给map赋值

<select id="getEmp" resultType="com.hand.mybatis.bean.Employee">
  SELECT * FROM emp WHERE eid=#{id} AND ename=#{ename}
 </select>

  如:
    Map<String, Object> map=new HashMap<>(); 
    map.put("id", 101);

map.put("ename", "张三");
    Employee employee=employeeMapper.getEmp(map);
    System.out.println(employee);

<!-- //集合List
  List<Employee> getEmpByeNameLike(String ename); -->
 <select id="getEmpByeNameLike" resultType="com.hand.mybatis.bean.Employee">
  SELECT * FROM emp WHERE ename like #{ename}
 </select>
 
 <!--  //返回一条记录的map;key就是列名,值是对应的值
 Map<String, Object> getEmpByIdReturnMap(Integer id); -->
 <select id="getEmpByIdReturnMap" resultType="map">
 SELECT * FROM emp WHERE eid=#{id}
 </select>

调用 Map<String, Object> getEmpByIdReturnMap(Integer id)接口:

Map<String, Object> map= employeeMapper.getEmpByIdReturnMap(101);
    System.out.println(map);

结果:

    {eid=101, ename=张三, gender=0, email=2714763867@qq.com, did=1}

<!-- //多条记录封装一个map:Map<Integer,Employee>:键是这条记录的主键,值是记录封装后的javaBean
    //告诉mybatis封装这个map的时候使用哪个属性作为map的key
    /*@MapKey("eId")
     Map<Integer, Employee> getEmpByLastNameLikeReturnMap(String ename);*/
    @MapKey("eName")
    Map<String, Employee> getEmpByLastNameLikeReturnMap(String ename); -->
 <select id="getEmpByLastNameLikeReturnMap" resultType="com.hand.mybatis.bean.Employee">
 SELECT * FROM emp WHERE ename like #{ename}
 </select>
调用:

Map<Integer, Employee> map=employeeMapper.getEmpByLastNameLikeReturnMap("%张%");
  System.out.println(map);

结果 {101=Employee [eId=101, ename=张三, gender=0, email=2714763867@qq.com], 102=Employee [eId=102, ename=张丽, gender=0,       email=163826386@qq.com], 103=Employee [eId=103, ename=杨张, gender=1, email=21901826380863@163.com]}

</mapper>

代码:https://github.com/shuaishuaihand/mybatis.git

mybatis的sql映射文件—增删改查的更多相关文章

  1. Mybatis(3) 映射文件-增删改查

    映射文件: 映射文件是根据数据库模型生成的编写sql脚本xml文件, mapper标签中namespace属性值为对应模型实体类的全类名. <?xml version="1.0&quo ...

  2. mybatis 学习四(下) SQL语句映射文件增删改查、参数、缓存

    2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id="getStudent" paramet ...

  3. SSMybatis整合 --详细解读Mybatis对oracle数据库进行增删改查(一)

    Mybatis是现在主流的持久化层框架,与Hibernate不同的是,它鼓励程序员使用原声SQL语句对数据库进行操作.因此提供了非常灵活的功能.特别是当数据库同时访问数过多,需要进行优化时,使用sql ...

  4. SpringBoot+Mybatis+Maven+MySQL逆向工程实现增删改查

    SpringBoot+Mybatis+MySQL+MAVEN逆向工程实现增删改查 这两天简单学习了下SpringBoot,发现这玩意配置起来是真的方便,相比于SpringMVC+Spring的配置简直 ...

  5. 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_3-2.使用Mybatis注解开发视频列表增删改查

    笔记 2.使用Mybatis注解开发视频列表增删改查     讲解:使用Mybatis3.x注解方式 增删改查实操, 控制台打印sql语句              1.控制台打印sql语句      ...

  6. Mybatis(二) SQL映射文件

    SQL映射文件 单条件查询 1. 在UserMapper接口添加抽象方法 //根据用户名模糊查询 List<User> getUserListByName(); 2. 在UserMappe ...

  7. 使用java对sql server进行增删改查

    import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...

  8. 四种简单的sql语句(增删改查语句)

    四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 dele ...

  9. dml语句就是你常写的sql语句,增删改查

    dml语句就是你常写的sql语句,增删改查

随机推荐

  1. Powershell替代和截断——replace and substring

    一:截取一个字符串的尾部,替代字符串中的特定字符或替代字符串中特定位置的特定字符 $a="W.endy.chen.SHAO" $b=$a.Substring(0,$a.Length ...

  2. Yii框架2.0的Gii

    Yii框架的Gii在我看来算是个快速创建器,当然对于学习来说意义不大,但对于已经懂得他的原理并用他开发的话,就是个快速开发的好工具. 他能快速的创建控制器,模块,crup,插件,Module. 打开g ...

  3. python pip命令技巧

    确保本地开发环境,和线上一致性 1.导出当前解释器的模块pip3 freeze > requirements.txt 2.将这个文件requirements.txt,上传至服务器,在新的虚拟环境 ...

  4. MyBatis3用户指南

    1. 范围和生命周期     SqlSessionFactoryBuilder -->SqlSessionFactory-->SqlSession-->Mapper 实例 SqlSe ...

  5. POJ3254:Corn Fields(状压dp第一发)

    题目:http://poj.org/problem?id=3254 直接上代码吧,刚开始做时主要的问题就是看不懂二进制,有个博客写的太好了,就直接把题解复制在下面了. #include <ios ...

  6. sdut3140 A*B(math)

    题目:传送门 题目描述 Your task is to find the minimal positive integer number Q so that the product of digits ...

  7. What does Quick Sort look like in Python?

    Let's talk about something funny at first. Have you ever implemented the Quick Sort algorithm all by ...

  8. JUnit之参数化测试、套件/成组测试的使用

    原文地址http://blog.csdn.net/yqj2065/article/details/39967065 参数化测试 正如数组替代int a0,a1,a2一样,测试加法时assertEqua ...

  9. 自定义admin管理工具(stark组件)

    自定义admin管理工具(stark组件) 创建项目 了解了admin的功能后,我们可以开始仿照admin编写我们自己的管理工具stark组件 首先创建一个新的项目,并创建三个app stark就是我 ...

  10. 清晰讲解LSB、MSB和大小端模式及网络字节序

    时隔一个月又回到了博客园写文章,很开心O(∩_∩)O~~ 今天在做需求的涉及到一个固件版本的概念,其中固件组的人谈到了版本号从MSB到LSB排列,检索查阅后将所得整理如下. MSB.LSB? MSB( ...