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 ...
随机推荐
- HTML文件转Word文件格式
这是我需要转换的HTML文件 第一步~ 使用我们的福昕阅读器将我们.html文件打开,如下图 第二步: 点击“文件”——“另存为”——选择一个你自己喜欢的位置存放文件,此时的文件已经被转换成了.pdf ...
- DNS分离解析IPV6与IPV4用户
IPV6改造中经常会遇到,网站使用了CDN,但是CDN厂商还不支持IPV6的情况,而AAAA.A.CNAME记录互相冲突,想实现IPV6用户得到AAAA记录,IPV4用户得到CNAME记录的需求. 解 ...
- 小刘的深度学习---CNN
前言: 前段时间我在树莓派上通过KNN,SVM等机器学习的算法实现了门派识别的项目,所用到的数据集是经典的MNIST.可能是因为手写数字与印刷体存在一些区别,识别率并是很不高.基于这样的情况,我打算在 ...
- 黑客攻防web安全实战详解笔记
如有不足,欢迎指出,谢谢! ----------------------------------------- 1,url传值 GET传值:其传递的值会附加到url上 POST传值:其传递的值不会加 ...
- spring boot+mybatis+swagger搭建
环境概述 使用的开发工具:idea 2018 3.4 环境:jdk1.8 数据库:MariaDB (10.2.21) 包管理:Maven 3.5 Web容器:Tomcat 8.0 开发机系统:Wind ...
- tensorflow enqueue_many传入多个值的列表传入异常问题————Shape () must have rank at least 1
tf 的队列操作enqueue_many传入的值是列表,但是放入[]列表抛异常 File "C:\Users\lihongjie\AppData\Local\Programs\Python\ ...
- Docker容器和本机之间的文件传输 使用Docker部署Tomcat项目
Docker容器和本机之间的文件传输. http://blog.csdn.net/leafage_m/article/details/72082011 使用Docker部署Tomcat项目 http: ...
- PHP使用Sublime Text3技巧
1 下载安装 2 安装Package Control 3 安装插件 4 快捷键 5 项目管理 6 设置代理 PHP开发时,笔者用过EditPlus3.Nodpad++.Vi.Vim和Netbeans, ...
- Scrum立会报告+燃尽图(Final阶段第三次)
此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2481 项目地址:https://coding.net/u/wuyy694 ...
- YQCB冲刺周第四天
上图站立会议 任务看板: 今天的任务:做登录身份的验证,区别普通用户和超级管理员 遇到的困难:中文乱码问题