Mybatis(3) 映射文件-增删改查
映射文件:
映射文件是根据数据库模型生成的编写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
, 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) 映射文件-增删改查的更多相关文章
- mybatis的sql映射文件—增删改查
前提:需要的包log4j.jar,mybatis-3.4.1.jar,mysql-connector-java-5.1.37-bin.jar 1.基本类 员工类 package com.hand.my ...
- mybatis 学习四(下) SQL语句映射文件增删改查、参数、缓存
2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id="getStudent" paramet ...
- MyBatis学习系列二——增删改查
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...
- Mybatis实现数据的增删改查
Mybatis实现数据的增删改查 1.项目结构(使用maven创建项目) 2.App.java package com.GetcharZp.MyBatisStudy; import java.io.I ...
- 【基础篇】js对本地文件增删改查
[基础篇] js对本地文件增删改查--增 js对本地文件增删改查--删 js对本地文件增删改查--改 js对本地文件增删改查--查
- 【基础篇】js对本地文件增删改查--查
前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...
- 【基础篇】js对本地文件增删改查--改
前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...
- 【基础篇】js对本地文件增删改查--删
前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...
- 【基础篇】js对本地文件增删改查--增
前置条件: 1. 本地有安装node,点击传送门 项目目录: 1. msg.json内容 { "data": [ { "id": 1, "name&q ...
随机推荐
- Machine Learning笔记整理 ------ (五)决策树、随机森林
1. 决策树 一般的,一棵决策树包含一个根结点.若干内部结点和若干叶子结点,叶子节点对应决策结果,其他每个结点对应一个属性测试,每个结点包含的样本集合根据属性测试结果被划分到子结点中,而根结点包含样本 ...
- CVPR-2018 那些有趣的新想法
Taylor Guo @ Shanghai - 2018.10.18 缘起 还有什么比顶级会议更适合寻找有趣新想法的地方吗?我们从CVPR 2018 计算机视觉和模式识别的顶级会议中发现了很多有趣的东 ...
- Trie 树——搜索关键词提示
当你在搜索引擎中输入想要搜索的一部分内容时,搜索引擎就会自动弹出下拉框,里面是各种关键词提示,这个功能是怎么实现的呢?其实底层最基本的就是 Trie 树这种数据结构. 1. 什么是 "Tri ...
- windows 7 安装docker
下载docker-install.exe 下载链接 安装,一路next(安装完成后建议重启电脑) 点击桌面boot2docker Start图标,等待初始化,运行docker --version检验是 ...
- 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 ...
- HADOOP/HDFS Essay
HDFS架构 the core of HADOOP/distributed systems is storeage(HDFS) and resource manager(YARN) for compu ...
- 由一个hash字符串生成多个子hash字符串
通过存储一个head hash,然后把子hash放到网络中 当然,也可以像默克尔树那样的,生成多级的子hash ,可以通过规则配置不同的hash 生成方式.倒置的默克尔树 我有一个文件,然后我把她分隔 ...
- python leveldb 文档
标签(空格分隔): python leveldb import leveldb db = leveldb.LevelDB('./db') db.Put('hello', 'world') print ...
- C++读取文件统计单词个数及频率
1.Github链接 GitHub链接地址https://github.com/Zzwenm/PersonProject-C2 2.PSP表格 PSP2.1 Personal Software Pro ...
- Java中的 toString 方法
1. Object 类中定义有 public String toString() 方法,其返回值是 String 类型,描述当前对象的有关信息: 2. 在进行 String 与其它类型数据的连接操作时 ...