映射文件:

映射文件是根据数据库模型生成的编写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. Java标签实现分页

    Java实现标签分页 最近为了开发一个网站,里面要用分页功能,但是之前很少自己写分页标签,又不想用现成框架.所以自己参考了些资料,写了个分页例子测试了一下. 代码主要分为三个类: PageTag 分页 ...

  2. 十二:NodeManager

    NM负责启动和管理节点上的containers.AM通过containers来运行任务. Health Checker Service 创建检查服务     NM运行一个检查服务来检查节点的状态,该服 ...

  3. ZOJ 3689 Digging(DP)

    Description When it comes to the Maya Civilization, we can quickly remind of a term called the end o ...

  4. Android 开发 之 JNI入门 - NDK从入门到精通

    NDK项目源码地址 : -- 第一个JNI示例程序下载 : GitHub - https://github.com/han1202012/NDKHelloworld.git -- Java传递参数给C ...

  5. Uva 1600 Patrol Robot (BFS 最短路)

    这道题运用的知识点是求最短路的算法.一种方法是利用BFS来求最短路. 需要注意的是,我们要用一个三维数组来表示此状态是否访问过,而不是三维数组.因为相同的坐标可以通过不同的穿墙方式到达. #inclu ...

  6. P4语法(2) Parser

    这里参考学习了: P4语言规范 P4台湾社群 Parser 关于parser 在P4程序中,有着大量的首部(header)和首部实例,但每次只有部分首部实例会对数据包进行操作,而parser会用于生成 ...

  7. eg_3

    3. 编写一个程序,返回一个 double 类型的二维数组,数组中的元素通过解析字符串参数获得,如字符串参数:“1,2;3,4,5;6,7,8”,则对应的数组为: d[0][0]=1.0, d[0][ ...

  8. MFC动态创建控件及其消息响应函数

    这几天专门调研了一下MFC中如何动态创建控件及其消息响应函数. 参考帖子如下: (1)http://topic.csdn.net/u/20101204/13/5f1b1e70-2f1c-4205-ba ...

  9. Swift-元祖

    1.元组是多个值组合而成的复合值.元组中的值可以是任意类型,而且每一个元素的类型可以是不同的. let http404Error = (,"Not Found") print(ht ...

  10. ZOJ 2072 K-Recursive Survival

    https://vjudge.net/contest/67836#problem/K n people numbered 1 to n around a circle, we eliminate ev ...