<?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的更多相关文章

  1. MyBatis:CRUD功能

    在前面已经自动生成了mapper和pojo,接下来我们实现mybatis的CRUD功能,先新建service.controller层的方法. 这里的sid是一个开源的id生成类,写完后,我们还需要在启 ...

  2. Mybatis的CRUD案例

    一.Mybatis增删改查案例 上一节<Mybatis入门和简单Demo>讲了如何Mybatis的由来,工作流程和一个简单的插入案例,本节主要继上一讲完整的展示Mybatis的CRUD操作 ...

  3. 【MyBatis】MyBatis实现CRUD操作

    1.实现基本CRUD功能 使用MyBatis对数据完整的操作,也就是CRUD功能的实现.根据之前的内容,要想实现CRUD,只需要进行映射文件的配置. 范例:修改EmpMapper.xml文件,实现CR ...

  4. SpringBoot 整合 Mybatis 进行CRUD测试开发

    今天来和大家分享下 Spring Boot 整合 MyBatis 的 CRUD 测试方法开发.因为 MyBaits 有两种开发形式,一种基于注解,一种基于 xml . SpringBoot配置文件也有 ...

  5. 基于mybatis的CRUD

    u  基于Mybatis的CRUD u  掌握MyBatis的结果类型-resultMap和resultType u  掌握MyBatis的参数类型 u  掌握#和$两种语法 1      基于myb ...

  6. 05 Mybatis的CRUD操作和Mybatis连接池

    1.CRUD的含义 CRUD是指在做计算处理时的增加(Create).读取(Retrieve)(重新得到数据).更新(Update)和删除(Delete)几个单词的首字母简写.主要被用在描述软件系统中 ...

  7. 03 Mybatis:05.使用Mybatis完成CRUD

    mybatis框架:共四天 明确:我们在实际开发中,都是越简便越好,所以都是采用不写dao实现类的方式.不管使用XML还是注解配置. 第二天:mybatis基本使用 mybatis的单表crud操作 ...

  8. mybatis(CRUD)

    3.mybatis(CRUD) 有了mybatis,我们要对数据库进行增删改查只需要操作接口和mapper.xml文件,然后进行测试就可以了. 实例代码如下: 接口 public interface ...

  9. MyBatis之CRUD

    1 mybatis框架介绍 1.1回顾jdbc操作数据库的过程 1.2 mybatis开发步骤 A.提供一个SqlMapperConfig.xml(src目录下),该文件主要配置数据库连接,事务,二级 ...

  10. MyBatis Tutorial – CRUD Operations and Mapping Relationships – Part 1---- reference

    http://www.javacodegeeks.com/2012/11/mybatis-tutorial-crud-operations-and-mapping-relationships-part ...

随机推荐

  1. v-if、v-show 指令

    HTML部分: <div id="app"> <button type="button" @click="flag=!flag&qu ...

  2. python—启动自带shell时报错(丢失api-ms-win-crt-runtime-l1-1-0.dll)已解决

    备注: 有的伙伴安装完1后重启,问题可以解决,summer儿在安装完1依然未能解决,于是又进行了2的安装再次重启后问题解决!! 1,安装vc-redist.x64,微软官网搜索免费下载,安装后重启. ...

  3. [redis] 几种redis数据导出导入方式

    环境说明: 172.20.0.1 redis源实例 172.20.0.2 redis目标实例 172.20.0.3 任意linux系统 一.redis-dump方式 1.安装redis-dump工具 ...

  4. gulp-babel 阻止了js文件编译的进程?

    现象 :   编译打包的js没有输出到目标文件夹里,只是单单的生成了一个目标目录,目录里没有文件 解决方法:gulp-babel ^8.0.0 使用了 ^7.0.1的 依赖插件.统一gulp-babe ...

  5. Visual Studio AI 离线模型训练(window 7)

    本篇博客用tensorflow训练自带的数据mnist,参考自博客. 背景: 搭建好AI环境:查看 window 7 64位 准备工作: 在搭建AI环境过程中下载的samples-for-ai不是最新 ...

  6. 第十二周作业_PSP总结报告

    回顾1 (1)回想一下你曾经对计算机专业的畅想 当初你是如何做出选择计算机专业的决定的?经过一个学期,你的看法改变了么,为什么? 你认为过去接触到的课程是否符合你对计算机专业的期待,为什么?经过一个学 ...

  7. (第十周)评论Beta发布

    本人所在组:奋斗吧兄弟 按课上展示的顺序对每组进行点评: 1.  飞天小女警 项目:礼物挑选工具 相对于alpha发布时有了很大的进步.项目的界面很漂亮,这个项目的想法很新颖,我很喜欢.礼物的挑选给出 ...

  8. CS小分队第二阶段冲刺站立会议(6月3日)

    昨日成果:完成了主界面按钮移动交换位置 遇到问题:最后的时候发现仅交换了按钮在数据库中的信息,对于按钮的链接忘记交换了 今日计划:解决这个问题,对这个冲刺阶段的成果进行整理

  9. 如何:通过将HTML编码应用于字符串来防止Web应用程序中的脚本漏洞

    当用户可以将可执行代码(或脚本)添加到您的应用程序中时,会发生大多数脚本攻击.默认情况下,ASP.NET提供请求验证,如果表单发布包含任何HTML,则会引发错误. 您可以通过以下方式帮助防止脚本漏洞利 ...

  10. CS学习

    作者:匿名用户链接:https://www.zhihu.com/question/27368268/answer/36464143来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注 ...