1、实现基本CRUD功能

使用MyBatis对数据完整的操作,也就是CRUD功能的实现。根据之前的内容,要想实现CRUD,只需要进行映射文件的配置。

范例:修改EmpMapper.xml文件,实现CRUD

<?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">
<!-- 每个POJO都对应MyBatis的一个命名空间,不能重复。
resultType使用全路径
设置命名空间,可以与不同表的同类型操作进行区分,使用时以“namespace.id”的方式调用;命名空间按照表名称给出 -->
<mapper namespace="com.github.logsave.pojo.EmpMapper"> <insert id="creatOne" parameterType="com.github.logsave.pojo.Emp">
INSERT INTO emp(empno,ename,job,mgr,hiredate,sal)
VALUES (#{empno},#{ename},#{job},#{mgr},#{hiredate},#{sal})
</insert> <!-- 数据更新操作,最简单的更新一定是基于Emp类的数据实现的 -->
<update id="updateOne" parameterType="com.github.logsave.pojo.Emp">
UPDATE emp SET empno=#{empno}, ename=#{ename}, job=#{job},
mgr=#{mgr}, hiredate=#{hiredate}, sal=#{sal}
WHERE empno={empno}
</update> <!-- 删除数据,一般根据主键删除empno,empno这里是Integer类型 -->
<delete id="removeOne" parameterType="java.lang.Integer">
DELETE FROM emp WHERE empno=#{empno}
</delete> <!-- 根据empno查询 -->
<select id="selOne" resultType="com.github.logsave.pojo.Emp">
SELECT empno,ename,job,mgr,hiredate,sal FROM emp
WHERE empno=#{empno}
</select> <!-- 查询全部数据,此时配置的resultType表示当前查询结果中每一条数据返回的对象类型,不是整个方法的返回。 -->
<select id="selAll" resultType="com.github.logsave.pojo.Emp">
SELECT empno,ename,job,mgr,hiredate,sal FROM emp
</select>
</mapper>

此时已经完成了映射文件的配置。就可以利用SqlSession类对象完成具体的操作,方法如下:

  • 增加数据:public int insert(String statrment, Object parameter), 返回增加的行数;
  • 删除数据:public int delete(String statrment, Object parameter), 返回删除的行数;
  • 更新数据:public int update(String statrment, Object parameter), 返回更新的行数;
  • 查询单个数据:public T selectOne(String statrment, Object parameter);
  • 查询全部数据:public List selectList(String statement)。

测试CRUD功能,分别编写函数进行测试。

范例:执行函数主方法

public static void main(String[] args) {

    try {
// 1、取得操作的SqlSession对象
String resource = "mybatis-config.xml"; // MyBatis配置文件路径
Reader reader = Resources.getResourceAsReader(resource); // 当前配置文件输入流
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); // 数据库会话工厂
SqlSession sqlSession = sqlSessionFactory.openSession(); // 取得连接 // 2、操作简单Java类
// 为了测试方便,将各个方法分别编写函数进行测试。在函数中改变方法内容进行测试。
// creat(sqlSession); // 增加数据
// selectByEmpNo(sqlSession,7499); // 按empno查询数据
// update(sqlSession); // 更新数据
// remove(sqlSession); // 删除数据
// selectAll(sqlSession); // 查询全部数据 sqlSession.close(); // 关闭连接
} catch(IOException e) {
e.printStackTrace();
}
}

范例:增加数据

public static void creat(SqlSession sqlSession) {
Emp emp = new Emp();
emp.setEmpno(7369);
emp.setEname("SMITH");
emp.setJob("CLERK");
emp.setMgr(7902); Calendar c = Calendar.getInstance();
c.set(1980,10,17);
Date date = c.getTime();
emp.setHiredate(date); emp.setSal(800.00); System.out.println("【INSERT】数据更新行数:"
    + sqlSession.insert("com.github.logsave.pojo.EmpMapper.creatOne",emp));
sqlSession.commit(); // 事务提交
}
【INSERT】数据更新行数:

范例:删除数据

public static void remove(SqlSession sqlSession) {
int empno = 7499; // 删除数据的empno
System.out.println("【DELETE】数据更新行数:" +
sqlSession.delete("com.github.logsave.pojo.EmpMapper.removeOne",empno));
sqlSession.commit();
}
【DELETE】数据更新行数:

范例:更新数据

public static void update(SqlSession sqlSession) {
Emp emp = new Emp();
emp.setEmpno(7369);
emp.setEname("Logsave");
emp.setJob("MANAGER");
// emp.setMgr(7839); // 注释掉数据库中对应值为null Calendar c = Calendar.getInstance();
c.set(2015,10,20);
Date date = c.getTime();
emp.setHiredate(date);
emp.setSal(1600.00); System.out.println("【UPDATE】数据更新行数:"
    + sqlSession.update("com.github.logsave.pojo.EmpMapper.updateOne",emp));
sqlSession.commit(); // 事务提交
}
【UPDATE】数据更新行数:

范例:查询单条数据

public static void selectByEmpNo(SqlSession sqlSession) {
int empno = 7369;
System.out.println("【SELECT】selectByEmpno:" + empno + "\n \t"
    + sqlSession.selectOne("com.github.logsave.pojo.EmpMapper.selOne",
empno));
}
【SELECT】selectByEmpno:
Emp [empno=, ename=Logsave, job=MANAGER, mgr=null, hiredate=Fri Nov :: CST , sal=1600.0]

范例:查询全部数据

public static void selectAll(SqlSession sqlSession) {
List<Emp> empList = sqlSession.selectList("com.github.logsave.pojo.EmpMapper.selAll");
System.out.println("【SELECT】selectAll:");
for(Emp emp: empList) {
System.out.println("\t" + emp);
}
}
【SELECT】selectAll:
Emp [empno=, ename=Logsave, job=MANAGER, mgr=null, hiredate=Fri Nov :: CST , sal=1600.0]
Emp [empno=, ename=WARD, job=SALESMAN, mgr=, hiredate=Thu Oct :: CST , sal=1250.0]

现在完成了MyBatis的CRUD操作,已经可以进行简单的操作了。

2、分页显示

实现了CRUD之后,我们就应该实现数据的分页显示。分页显示所需要的参数:

  • 模糊查询的列:column;
  • 模糊查询关键字:keyWord;
  • 开始行:start(currentPage *lineSize)
  • 取得数据的长度:lineSize。

注意:MySQL中使用LIMIT进行分页,在Oracle中使用伪列ROWNUM进行分页操作。

实现分页操作需要多个参数,那么这些参数需要一次性传递完成,这个时候就需要设置Map集合,利用Map集合完成参数传递。

范例:修改EmpMapper.xml文件

  <!-- 定义分页查询,其中所有的参数都利用Map集合传递,返回的每行数据类型为Emp -->
<select id="selAllBySplit" parameterType="java.util.Map" resultType="com.github.logsave.pojo.Emp">
SELECT empno,ename,job,mgr,hiredate,sal FROM emp
WHERE ${column} LIKE #{keyWord}
LIMIT #{start}, #{lineSize}
</select> <!-- 查询全部数据量,参数使用Map集合,返回COUNT()的统计结果 -->
<select id="count" parameterType="java.util.Map" resultType="java.lang.Integer">
SELECT COUNT(empno) FROM emp
WHERE ${column} LIKE #{keyWord}
</select>

下面的查询依然需要的是查询全部数据,但是需要传递参数:

  • 查询全部数据:public List selectList(String statement)

范例:实现分页查询

public static void split(SqlSession sqlSession) {
// 分页操作必要的参数
int currentPage = 1; // 当前所在页
int lineSize = 3; // 每页显示的长度
// 需要将参数设置为Map集合后传递到调用的方法里
Map<String, Object> map = new HashMap<String, Object>();
map.put("column", "ename");
map.put("keyWord", "%o%");
map.put("start", (currentPage - 1) * lineSize);
map.put("lineSize", lineSize);
List<Emp> empList = sqlSession.selectList("com.github.logsave.pojo.EmpMapper.selAllBySplit", map);
System.out.println("【SELECT】分页操作:");
for(Emp emp: empList) {
System.out.println("\t" + emp);
}
}
【SELECT】分页操作:
Emp [empno=, ename=Logsave, job=MANAGER, mgr=null, hiredate=Fri Nov :: CST , sal=1600.0]
Emp [empno=, ename=Hello, job=work, mgr=, hiredate=Tue Jan :: CST , sal=1800.0]
Emp [empno=, ename=nihao, job=work, mgr=, hiredate=Mon Feb :: CST , sal=1800.0]

范例:统计数据行数

public static void count(SqlSession sqlSession) {
Map<String, Object> map = new HashMap<String, Object>();
map.put("column", "ename");
map.put("keyWord", "%o%");
System.out.println("【COUNT】数据个数:"
+ sqlSession.selectOne("com.github.logsave.pojo.EmpMapper.count", map) );
}
【COUNT】数据个数:

程序源码

【MyBatis】MyBatis实现CRUD操作的更多相关文章

  1. 使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  2. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  3. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

  4. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...

  5. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  6. mybatis(二)执行CRUD操作的两种方式配置和注解

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  7. MyBatis学习总结_02_使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...

  8. 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    [转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...

  9. Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】

    一.使用Mybatis对表进行CRUD操作------基于XML的实现 1.定义SQL的映射文件 2.在conf.xml中进行注册. 2.创建测试类 [具体过程参考:Mybatis的学习总结一] 二. ...

  10. 【Mybatis】MyBatis对表执行CRUD操作(三)

    本例在[Mybatis]MyBatis配置文件的使用(二)基础上继续学习对表执行CRUD操作 使用MyBatis对表执行CRUD操作 1.定义sql映射xml文件(EmployeeMapper.xml ...

随机推荐

  1. 【扫盲】】32位和64位Windows的区别

    用户购买windows安装盘或者重新安装操作系统的时候,通常会遇到这个问题,就是不知道该如何选择使用32位操作系统和64位操作系统,有人说64位系统速度快,其实理论上确实是这样,不过具体还要根据你的个 ...

  2. 【angular5项目积累总结】自定义管道 OrderBy

    import { Injectable, Pipe } from '@angular/core'; @Pipe({ name: 'orderBy' }) @Injectable() export cl ...

  3. SQL Serever学习13——数据库编程语言

    编程基础 注释 注释命名来对一些语句进行说明,便于日后维护或者其他用户理解,注释不会执行. 单行注释 SELECT GETDATE() --查询当前日期 多行注释 /* 注释有助于 理解操作的内容 查 ...

  4. 从java到web前端再到php,一路走来的小总结

    java的学习: 初学者对Java的学习,上来的感觉都是比较难,感觉java的东西很多,如此多的类和接口.有时还弄不懂为啥实例化出一个int空数组为什么数组中默认都是0,实例化一个空字符串数组时(St ...

  5. Visual Studio for Mac 安装无响应或者无法连接网络等解决方法

    1.无法连接到网络 2.点击安装和更新无响 这两种情况造成的原因都是由于被墙的原因,第一种情况有部分可以通过fq解决,第二种情况是我遇到过的 反正我全局也失败 这里给出一个我自己用过的解决方案 查看控 ...

  6. 【13】MD5编码、Zlib压缩解压缩

    1.MD5加密 /// <summary> /// 使用MD5加密算法 /// </summary> /// <param name="md5MessageSt ...

  7. java二叉搜索树原理与实现

    计算机里面的数据结构 树 在计算机存储领域应用作用非常大,我之前也多次强调多磁盘的存取速度是目前计算机飞速发展的一大障碍,计算机革命性的的下一次飞跃就是看硬盘有没有质的飞跃,为什么这么说?因为磁盘是永 ...

  8. HTTP 错误500.19 - 错误代码 0x80070021

    1.错误描述 HTTP 错误500.19 -Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效. 详细错误信息 模块 IIS Web Core  通知 Begi ...

  9. BZOJ2960:跨平面

    题面 BZOJ Sol 对该平面图的对偶图建图后就是最小树形图,建一个超级点向每个点连 \(inf\) 边即可 怎么转成对偶图,怎么弄出多边形 把边拆成两条有向边,分别挂在两个点上 每个点的出边按角度 ...

  10. PHP之SimpleXML函数

    使用php创建XML文件十分简单,使用SimpleXML那就更简便了,同时读取XML文件也十分方便.XML文件是直接在浏览器中打开,以自定义标签的方式直观简洁的方式展示给读者. 1.创建XML文件 h ...