MyBatis.3.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"> <mapper namespace="org.mybatis.example.dao.DeptMapper"> <select id="selectOne" parameterType="int" resultType="org.mybatis.example.dao.Dept"> select * from dept where deptno=#{id} </select> <insert id="insertDept" parameterType="org.mybatis.example.dao.Dept" useGeneratedKeys="true" keyProperty="dept"> insert into dept(dname,loc) values( #{dname,jdbcType=VARCHAR}, #{loc,jdbcType=VARCHAR}) </insert> <update id="updateDept" parameterType="org.mybatis.example.dao.Dept"> update dept set dname=#{dname},loc=#{loc} where deptno=#{deptno} </update> <delete id="deleteDept" parameterType="java.lang.Integer"> delete from dept where deptno=#{id} </delete> </mapper>
package org.mybatis.example.dao; public interface DeptMapper { public Dept selectOne(int id); public int insertDept(Dept dept); public int updateDept(Dept dept); public int deleteDept(int id); }
import java.io.IOException; import java.io.Reader; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import org.mybatis.example.dao.Dept; import org.mybatis.example.dao.DeptMapper; public class Test2 { public static void main(String[] args) throws IOException { String resource="mybatisConfig.xml"; Reader reader=Resources.getResourceAsReader(resource); SqlSessionFactory sqlMapper=new SqlSessionFactoryBuilder().build(reader); SqlSession session=sqlMapper.openSession(); try { DeptMapper mapper=session.getMapper(DeptMapper.class); //1.查询 // Dept dept=mapper.selectOne(2); // System.out.println(dept.getDname()); //2.插入操作 Dept dept=new Dept(); dept.setDname("张沅湲"); dept.setLoc("郑州"); mapper.insertDept(dept); session.commit();//实现增加 修改 删除 //3.更新操作; // Dept dept=new Dept(); // dept.setDeptno(3); // dept.setDname("张沅湲"); // dept.setLoc("湖南"); // mapper.updateDept(dept); // session.commit(); //4.删除操作; // int i=mapper.deleteDept(3); // session.commit(); // System.out.println(i); } catch (Exception e) { e.printStackTrace(); }finally{ session.close(); } } }
复杂的查询,在项目开发中,可以使用一个工具类来封装这些复杂的步骤:
package org.mybatis.example.dao; import java.io.Reader; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class SqlSessionFactoryUtil { private static SqlSessionFactory factory; public SqlSessionFactoryUtil() {} static{ Reader reader=null; try { reader=Resources.getResourceAsReader("mybatisConfig.xml"); factory=new SqlSessionFactoryBuilder().build(reader); } catch (Exception e) { e.printStackTrace(); }finally{ try { if(reader!=null)reader.close(); } catch (Exception e2) { e2.printStackTrace(); } } } public static SqlSession getSqlSession(){ return factory.openSession(); } }
DeptMapper接口的完全代码:
package org.mybatis.example.dao; import java.util.List; public interface DeptMapper { public Dept selectOne(int id); public int insertDept(Dept dept); public int updateDept(Dept dept); public int deleteDept(int id); public List<Dept>selectAllDepts(); public List<Dept>selectByCriteria(String deptName); }
1.查询所有部门信息参考代码;
<select id="selectAllDepts" resultType="org.mybatis.example.dao.Dept" > select deptno,dname,loc from dept </select>
测试代码;
import java.util.List; import org.apache.ibatis.session.SqlSession; import org.mybatis.example.dao.Dept; import org.mybatis.example.dao.DeptMapper; import org.mybatis.example.dao.SqlSessionFactoryUtil; public class Test3 { public static void main(String[] args) { SqlSession session=SqlSessionFactoryUtil.getSqlSession(); try { DeptMapper mapper=session.getMapper(DeptMapper.class); List<Dept>depts=mapper.selectAllDepts(); for(Dept dept:depts){ System.out.println("部门名称:"+dept.getDname()); } } catch (Exception e) { e.printStackTrace(); }finally{ session.close(); } } }
2.按条件查询,映射文件做以下修改,新增条件为模糊查询方法:
<!-- 按条件查询 --> <select id="selectByCriteria" parameterType="java.lang.String" resultType="org.mybatis.example.dao.Dept"> select deptno,dname,loc from dept where dname like '%${_parameter}%' </select>
测试代码
import java.util.List; import org.apache.ibatis.session.SqlSession; import org.mybatis.example.dao.Dept; import org.mybatis.example.dao.DeptMapper; import org.mybatis.example.dao.SqlSessionFactoryUtil; //按照条件进行查询; public class Test4 { public static void main(String[] args) { SqlSession session=SqlSessionFactoryUtil.getSqlSession(); try { DeptMapper mapper=session.getMapper(DeptMapper.class); List<Dept>depts=mapper.selectByCriteria("网络部"); for(Dept dept:depts){ System.out.println("部门名称:"+dept.getDname()); } } catch (Exception e) { e.printStackTrace(); }finally{ session.close(); } } }
MyBatis.3.CRUD的更多相关文章
- MyBatis:CRUD功能
在前面已经自动生成了mapper和pojo,接下来我们实现mybatis的CRUD功能,先新建service.controller层的方法. 这里的sid是一个开源的id生成类,写完后,我们还需要在启 ...
- Mybatis的CRUD案例
一.Mybatis增删改查案例 上一节<Mybatis入门和简单Demo>讲了如何Mybatis的由来,工作流程和一个简单的插入案例,本节主要继上一讲完整的展示Mybatis的CRUD操作 ...
- 【MyBatis】MyBatis实现CRUD操作
1.实现基本CRUD功能 使用MyBatis对数据完整的操作,也就是CRUD功能的实现.根据之前的内容,要想实现CRUD,只需要进行映射文件的配置. 范例:修改EmpMapper.xml文件,实现CR ...
- SpringBoot 整合 Mybatis 进行CRUD测试开发
今天来和大家分享下 Spring Boot 整合 MyBatis 的 CRUD 测试方法开发.因为 MyBaits 有两种开发形式,一种基于注解,一种基于 xml . SpringBoot配置文件也有 ...
- 基于mybatis的CRUD
u 基于Mybatis的CRUD u 掌握MyBatis的结果类型-resultMap和resultType u 掌握MyBatis的参数类型 u 掌握#和$两种语法 1 基于myb ...
- 05 Mybatis的CRUD操作和Mybatis连接池
1.CRUD的含义 CRUD是指在做计算处理时的增加(Create).读取(Retrieve)(重新得到数据).更新(Update)和删除(Delete)几个单词的首字母简写.主要被用在描述软件系统中 ...
- 03 Mybatis:05.使用Mybatis完成CRUD
mybatis框架:共四天 明确:我们在实际开发中,都是越简便越好,所以都是采用不写dao实现类的方式.不管使用XML还是注解配置. 第二天:mybatis基本使用 mybatis的单表crud操作 ...
- mybatis(CRUD)
3.mybatis(CRUD) 有了mybatis,我们要对数据库进行增删改查只需要操作接口和mapper.xml文件,然后进行测试就可以了. 实例代码如下: 接口 public interface ...
- MyBatis之CRUD
1 mybatis框架介绍 1.1回顾jdbc操作数据库的过程 1.2 mybatis开发步骤 A.提供一个SqlMapperConfig.xml(src目录下),该文件主要配置数据库连接,事务,二级 ...
- MyBatis Tutorial – CRUD Operations and Mapping Relationships – Part 1---- reference
http://www.javacodegeeks.com/2012/11/mybatis-tutorial-crud-operations-and-mapping-relationships-part ...
随机推荐
- SQLMAP学习笔记1 access注入
SQLMAP学习笔记1 access注入 Sqlmap是开源的自动化SQL注入工具,由Python写成,具有如下特点: 完全支持MySQL.Oracle.PostgreSQL.Microsoft S ...
- aircrack-ng无线破解实验
查看无线网卡 airmon-ng 开启网卡监听模式 airmon-ng start wlan0 扫描附近的wifi airodump-ng wlan0mon 停止扫描: ctrl c 使用airodu ...
- openssl在多平台和多语言之间进行RSA加解密注意事项
首先说一下平台和语言: 系统平台为CentOS6.3,RSA加解密时使用NOPADDING进行填充 1)使用C/C++调用系统自带的openssl 2)Android4.2模拟器,第三方openssl ...
- 编写webpack 插件
Webpack插件为第三方开发者释放了Webpack的最大可能性.利用多级回调开发者可以把他们自己的需要的功能引入到Webpack里面来.Build插件比Build loader 更进一步.因为你需要 ...
- 开发简单的IO多路复用web框架
自制web框架 1.核心IO多路复用部分 # -*- coding:utf-8 -*- import socket import select class Snow(): def __init__(s ...
- 软件工程-东北师大站-第十次作业(PSP)
1.本周PSP 2.本周进度条 3.本周累计进度图 代码累计折线图 博文字数累计折线图 4.本周PSP饼状图
- mybatis之模糊查询SQL
一,MySQL数据库 name like concat('%' , #{name} , '%') 二,Oracle数据库 name like '%' || #{name} || '%'
- 20172319 2018.04.11-16 《Java程序设计教程》 第6周学习总结
20172319 2018.04.11-16 <Java程序设计教程>第6周学习总结 目录 教材学习内容总结 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 上周考试错题 ...
- week2-作业2
项目地址:https://git.coding.net/Rainoob/calculate.git ·1.需求分析:程序可以根据输入的参数n随机产生n道四则运算计算题,每个数字在0-100之间.运算符 ...
- vue 实战语法错误导致的问题记录
1. 在组件中引入mapActions import mapActions from 'vuex' 而不是 getActions 2.引入 mutations-type.js import ...