映射文件:

映射文件是根据数据库模型生成的编写sql脚本xml文件, mapper标签中namespace属性值为对应模型实体类的全类名。

 <?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.itdoc.mybatis.bc.dao.EmployeeMapper"> <select id="queryById" resultType="com.itdoc.mybatis.bc.entity.EmployeeEntity">
SELECT
id AS `id`
, last_name AS `name`
, email AS `email`
, gender AS `gender`
FROM employee a
WHERE 1 = 1
AND id = #{id}
</select> <insert id="insert" parameterType="com.itdoc.mybatis.bc.entity.EmployeeEntity">
INSERT INTO employee (
last_name
, email
, gender)
VALUES (
#{name}
, #{email}
, #{gender}
)
</insert> <update id="update" parameterType="com.itdoc.mybatis.bc.entity.EmployeeEntity">
UPDATE employee
SET last_name = #{name}
, email = #{email}
, gender = #{gender}
WHERE 1 = 1
AND id = #{id}
</update> <delete id="delById">
DELETE
FROM employee
WHERE 1 = 1
AND id = #{id}
</delete>
</mapper>

EmployeeMapper.xml

EmployeeMapper.java接口:全类名com.itdoc.mybatis.bc.dao.EmployeeMapper

 /**
* @filename: EmployeeMapper.java
* @desc 数据库模型映射接口
* @author: Wang Chinda
* @blog http://www.cnblogs.com/goodcheap
* @date: 2018-01-30 10:15
* @version: v1.0
* @copyright: Copyright © 2018 ༄ྂ祸ྂྂ害ོ༘苍ྂྂ生ོ༘࿐ྂ 版权所有
* @modify_history: -
* 20180130 Wang Chinda create
* 20180130 Wang Chinda modify method()
*/
package com.itdoc.mybatis.bc.dao; import com.itdoc.mybatis.bc.entity.EmployeeEntity;
import com.itdoc.mybatis.common.base.dao.BaseDao; /**
* @desc 数据库模型映射接口
* @author Wang Chinda
* @create 2018-01-30 10:15
*/
public interface EmployeeMapper extends BaseDao<EmployeeEntity> { }

EmployeeMapper

 /**
* @filename: BaseDao.java
* @desc 基础数据模型接口
* @author: Wang Chinda
* @blog http://www.cnblogs.com/goodcheap
* @date: 2018-01-30 10:35
* @version: v1.0
* @copyright: Copyright © 2018 ༄ྂ祸ྂྂ害ོ༘苍ྂྂ生ོ༘࿐ྂ 版权所有
* @modify_history: -
* 20180130 Wang Chinda create
* 20180130 Wang Chinda modify method()
*/
package com.itdoc.mybatis.common.base.dao; /**
* @desc 基础数据模型接口
* @author Wang Chinda
* @create 2018-01-30 10:35
*/
public interface BaseDao<T> { /**
* 根据对象保存数据
* @param entity
* @return
*/
boolean insert(T entity); /**
* 根据主键删除数据
* @param id
* @return
*/
boolean delById(String id); /**
* 根据对象删除数据
* @param entity
* @return
*/
boolean del(T entity); /**
* 根据对象更新数据
* @param entity
* @return
*/
boolean update(T entity); /**
* 根据主键查询数据
* @param id
* @return
*/
T queryById(String id);
}

BaseDao

注意: 此处命名空间对应是为增删改查时方法名与标签id对应。如: BaseDao 中的 insert 方法对应 EmployeeMapper.xml 中 id 为 insert 的 <insert> 标签, 执行此标签中的 SQL 脚本。

运行示例:

testInsert方法数据库中数据:

testUpdate方法数据库中数据:

testSelcet方法控制台显示:

testDelete方法数据库中数据:

GitHub源码: mybatis-02

Mybatis(3) 映射文件-增删改查的更多相关文章

  1. mybatis的sql映射文件—增删改查

    前提:需要的包log4j.jar,mybatis-3.4.1.jar,mysql-connector-java-5.1.37-bin.jar 1.基本类 员工类 package com.hand.my ...

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

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

  3. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  4. Mybatis实现数据的增删改查

    Mybatis实现数据的增删改查 1.项目结构(使用maven创建项目) 2.App.java package com.GetcharZp.MyBatisStudy; import java.io.I ...

  5. 【基础篇】js对本地文件增删改查

    [基础篇] js对本地文件增删改查--增 js对本地文件增删改查--删 js对本地文件增删改查--改 js对本地文件增删改查--查

  6. 【基础篇】js对本地文件增删改查--查

    前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...

  7. 【基础篇】js对本地文件增删改查--改

    前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...

  8. 【基础篇】js对本地文件增删改查--删

    前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...

  9. 【基础篇】js对本地文件增删改查--增

    前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...

随机推荐

  1. [2017 - 2018 ACL] 对话系统论文研究点整理

    (论文编号及摘要见 [2017 ACL] 对话系统. [2018 ACL Long] 对话系统. 论文标题[]中最后的数字表示截止2019.1.21 google被引次数) 1. Domain Ada ...

  2. Linux内核设计笔记10——内核同步

    Linux内核同步笔记 几个基本概念 - 临界区(critical region):访问和操作共享数据的代码段: - 原子操作:操作在执行中不被打断,要么不执行,要么执行完: - 竞争条件: 两个线程 ...

  3. python函数中的位置参数、默认参数、关键字参数、可变参数区别

    一.位置参数 调用函数时根据函数定义的参数位置来传递参数. #!/usr/bin/env python # coding=utf-8 def print_hello(name, sex): sex_d ...

  4. 学霸系统UI项目功能说明书 v1.0版本

    发布人员:软件工程实践小队. 发布内容:学霸系统UI项目说明书. 版本:学霸v1.0版本. 学霸系统UI项目说明书 v1.0版本分为以下部分: Part 1:用户须知: Part 2:功能实现: Pa ...

  5. Java 动态绑定和多态

    动态绑定和多态 动态绑定是指:"在执行程序期间(而非编译期间),判断引用所指对象的实际类型,调用其相应的方法." 动态绑定(多态)存在的条件 要有继承. 要有重写. 父类引用指向子 ...

  6. 如何修改git push时的密码

    如何修改git push时的密码 如下: 打开git bash 输入 cd ~/.ssh ls 确定有 id_rsa 和 id_rsa.pub文件 ssh-keygen -p -f id_rsa 第一 ...

  7. sql分页使用join提高性能

    今天在分析系统中的分页sql时意外知道了使用join可以提高分页性能. 逻辑是join部分使用单一表,单一字段排序分页,然后join大表.

  8. 总结Canvas和SVG的区别

    参考链接: 菜鸟教程 HTML5 内联SVG 经典面试题(讨论canvas与svg的区别) Canvas SVG 通过 JavaScript 来绘制 2D 图形 是一种使用 XML 描述 2D 图形的 ...

  9. lintcode-30-插入区间

    插入区间 给出一个 无重叠 的按照区间起始端点排序的区间列表. 在列表中插入一个新的区间,你要确保列表中的区间仍然有序且 不重叠 (如果有必要的话,可以合并区间). 样例 插入区间[2, 5] 到 [ ...

  10. Zigbee安全基础篇Part.3

    原文地址: https://www.4hou.com/wireless/14294.html 导语:在之前的文章中提供了ZigBee协议及其安全功能的简要概述.在本文中,我们将探讨可在ZigBee网络 ...