前提:需要的包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. OKEx量化分析报告[2017-12-09]

    OKEx量化分析报告[2017-12-09] [分析时间]2017-12-09 15:24 [分析对象]OKEx [计价币种]USDT [报告内容]DASH_USDT短期    -3.8中期     ...

  2. uchome android 开发记录

    一.uchome 1.无法转移临时图片到服务器指定目录 cp_upload.php----------- function.cp.php ---------mobile_picture_tempora ...

  3. python-gitlab 模块

    安装:pip install python-gitlab import gitlab # 登录 gl = gitlab.Gitlab('http://127.0.0.1', private_token ...

  4. django cookie 提供的功能 参数

    # 用户发来数据带来所有COOKIES 这个cookie是字典 request.COOKIES # 获取字典 获取cookierequest.COOKIES["username111&quo ...

  5. mysql 下的命令

    1.查看mysql日志vim /var/log/mysqld.log

  6. 从iOS的图片圆角想到渲染

    圆角是一种很常见的视图效果,相比于直角,它更加柔和优美,易于接受.设置圆角会带来一定的性能损耗,如何提高性能是一个需要重点讨论的话题. 大家常见的圆角代码x.layer.cornerRadius = ...

  7. SHUOJ Arithmetic Sequence (FFT)

    链接:http://acmoj.shu.edu.cn/problem/533/ 题意:求一个序列中,有多少三元组(其中元素不重复)在任意的排列下能构成等差数列. 分析:等差数列:\(A_j-A_i=A ...

  8. 如何通过包名打开手机里的APP

    目前已知的打开APP的方式有两种, 一种是通过openUrl打开,这种有一个严重的问题,即必须添加白名单,白名单之外的APP即时安装了也无法打开. 另一种就是今天的重点,通过包名打开APP.先上核心代 ...

  9. wait、notify为什么要放在同步代码块中

    等待方遵循的原则: 获取对象的锁,不满足条件就调用wait()方法,条件满足继续执行 通知方原则: 获取对象的锁,改变条件,然后notify 每个对象都有一个监视器锁,这个监视器锁的数据结构如下: w ...

  10. ls命令输出的文件颜色

    ls的输出颜色不止3种,有以下几种,白色:表示普通文件蓝色:表示目录绿色:表示可执行文件红色:表示压缩文件浅蓝色:链接文件红色闪烁:表示链接的文件有问题 黄色:表示设备文件 灰色:表示其他文件 这是l ...