mybatis的sql映射文件—增删改查
前提:需要的包log4j.jar,mybatis-3.4.1.jar,mysql-connector-java-5.1.37-bin.jar
1.基本类
员工类
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.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);
结果:
<!-- //多条记录封装一个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映射文件—增删改查的更多相关文章
- Mybatis(3) 映射文件-增删改查
映射文件: 映射文件是根据数据库模型生成的编写sql脚本xml文件, mapper标签中namespace属性值为对应模型实体类的全类名. <?xml version="1.0&quo ...
- mybatis 学习四(下) SQL语句映射文件增删改查、参数、缓存
2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id="getStudent" paramet ...
- SSMybatis整合 --详细解读Mybatis对oracle数据库进行增删改查(一)
Mybatis是现在主流的持久化层框架,与Hibernate不同的是,它鼓励程序员使用原声SQL语句对数据库进行操作.因此提供了非常灵活的功能.特别是当数据库同时访问数过多,需要进行优化时,使用sql ...
- SpringBoot+Mybatis+Maven+MySQL逆向工程实现增删改查
SpringBoot+Mybatis+MySQL+MAVEN逆向工程实现增删改查 这两天简单学习了下SpringBoot,发现这玩意配置起来是真的方便,相比于SpringMVC+Spring的配置简直 ...
- 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_3-2.使用Mybatis注解开发视频列表增删改查
笔记 2.使用Mybatis注解开发视频列表增删改查 讲解:使用Mybatis3.x注解方式 增删改查实操, 控制台打印sql语句 1.控制台打印sql语句 ...
- Mybatis(二) SQL映射文件
SQL映射文件 单条件查询 1. 在UserMapper接口添加抽象方法 //根据用户名模糊查询 List<User> getUserListByName(); 2. 在UserMappe ...
- 使用java对sql server进行增删改查
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...
- 四种简单的sql语句(增删改查语句)
四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 dele ...
- dml语句就是你常写的sql语句,增删改查
dml语句就是你常写的sql语句,增删改查
随机推荐
- FormsAuthentication 使用指南
配置安全鉴别 鉴别是指鉴定来访用户是否合法的过程.ASP.NET Framework支持三种鉴别类型: Windows鉴别: NET Passport鉴别: Forms鉴别. 对于某一特定的应用程序, ...
- 【keras框架】
更高级别的封装.更简单的api,以tensorflow.theano为后端,支持更多的平台 读取网络模型后生成网络结构图 读取 from keras.models import load_model ...
- 使用JCONSOLE远程监控JVM
启动JMS服务 JConsole是从Java 5中开始引入的一个用于对JVM性能和资源消耗进行监控的图形化工具.JConsole可以连接本地的Java程序,也可以连接远程的Java程序.由于是GUI的 ...
- C++ 带有通配符*与?的字符串匹配
题目:两个字符串,一个是普通字符串,另一个含有*和?通配符,*代表零个到多个任意字符,?代表一个任意字符,通配符可能多次出现.写一个算法,比较两个字符串是否相等. 发现许多公司笔试面试都有这道题目,于 ...
- SonarQube+jenkins+maven平台搭建
SonarQube代码质量管理 1.配置jdk和maven jenkins - 系统管理 - 全局工具配置 jdk安装: # which java# /usr/local/java/jdk1.8.0. ...
- Node.js 入门资料
小毛驴的阿凡提的 Node.js 入门笔记 http://www.cnblogs.com/Afanty/category/1007304.html
- springboot使用tomcat apr模式
因需项目对并发要求比较高.提高Tomcat效率.使用tomcat apr模式.今天在这记录下使用过程.apr全称为apache portable runtime.这里套用下wiki对apr的解释. T ...
- centos7部署PaaS平台环境(mesos+marathon)
假如有5台主机可以使用,ip地址如下 规划(2master+3slave) master: 192.168.248.205 ---master1 192.168.248.206 ---master2 ...
- TensorFlow学习笔记(六)循环神经网络
一.循环神经网络简介 循环神经网络的主要用途是处理和预测序列数据.循环神经网络刻画了一个序列当前的输出与之前信息的关系.从网络结构上,循环神经网络会记忆之前的信息,并利用之前的信息影响后面节点的输出. ...
- Java基础知识陷阱(五)
本文发表于本人博客. 今天我来说说关于静态变量初始化.数组.==与equals的问题,看下面代码: public class Test{ private final int age; private ...