映射文件:

映射文件是根据数据库模型生成的编写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. Machine Learning笔记整理 ------ (五)决策树、随机森林

    1. 决策树 一般的,一棵决策树包含一个根结点.若干内部结点和若干叶子结点,叶子节点对应决策结果,其他每个结点对应一个属性测试,每个结点包含的样本集合根据属性测试结果被划分到子结点中,而根结点包含样本 ...

  2. CVPR-2018 那些有趣的新想法

    Taylor Guo @ Shanghai - 2018.10.18 缘起 还有什么比顶级会议更适合寻找有趣新想法的地方吗?我们从CVPR 2018 计算机视觉和模式识别的顶级会议中发现了很多有趣的东 ...

  3. Trie 树——搜索关键词提示

    当你在搜索引擎中输入想要搜索的一部分内容时,搜索引擎就会自动弹出下拉框,里面是各种关键词提示,这个功能是怎么实现的呢?其实底层最基本的就是 Trie 树这种数据结构. 1. 什么是 "Tri ...

  4. windows 7 安装docker

    下载docker-install.exe 下载链接 安装,一路next(安装完成后建议重启电脑) 点击桌面boot2docker Start图标,等待初始化,运行docker --version检验是 ...

  5. CDH/Hadoop 5.15 installation steps

    I will talk the main steps to install CDH 5.15 on Linux(CENT OS 6.10).  The installation method is M ...

  6. HADOOP/HDFS Essay

    HDFS架构 the core of HADOOP/distributed systems is storeage(HDFS) and resource manager(YARN) for compu ...

  7. 由一个hash字符串生成多个子hash字符串

    通过存储一个head hash,然后把子hash放到网络中 当然,也可以像默克尔树那样的,生成多级的子hash ,可以通过规则配置不同的hash 生成方式.倒置的默克尔树 我有一个文件,然后我把她分隔 ...

  8. python leveldb 文档

    标签(空格分隔): python leveldb import leveldb db = leveldb.LevelDB('./db') db.Put('hello', 'world') print ...

  9. C++读取文件统计单词个数及频率

    1.Github链接 GitHub链接地址https://github.com/Zzwenm/PersonProject-C2 2.PSP表格 PSP2.1 Personal Software Pro ...

  10. Java中的 toString 方法

    1. Object 类中定义有 public String toString() 方法,其返回值是 String 类型,描述当前对象的有关信息: 2. 在进行 String 与其它类型数据的连接操作时 ...