一、使用Mybatis对表进行CRUD操作------基于XML的实现

1、定义SQL的映射文件

2、在conf.xml中进行注册。

2、创建测试类

【具体过程参考:Mybatis的学习总结一】

二、使用Mybatis对表进行CRUD操作----基于注解的实现

  1、定义SQL映射的注解接口

  ITaskMapper接口代码如下:

package com.cn.mybatis.mapper;

import java.util.List;

import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update; import com.cn.mybatis.model.EdiTestTask; public interface ITaskMapper { @Insert("INSERT into edi_test_task(task_id,task_name,task_type,task_owner) values(#{task_id},#{task_name},#{task_type},#{task_owner})")
public int addTask(EdiTestTask editt); @Update("UPDATE edi_test_task set task_name=#{task_name},task_type=#{task_type}, task_owner=#{task_owner} where task_id=#{task_id}")
public int updateTask(EdiTestTask editt); @Delete("delete from edi_test_task where task_id =#{taskId} ")
public int deleteTask(String taskId); @Select("select * from edi_test_task where task_id=#{taskId}")
public EdiTestTask getTaskById(String taskId); @Select("select * from edi_test_task")
public List<EdiTestTask> getAllTasks();
}

注意:我们不需要针对ITaskMapper接口去编写具体的实现类代码,这个具体的实现类由MyBatis帮我们动态构建出来,我们只需要直接拿来使用即可。

2、在配置文件conf.xml中注册以上接口:

  <mappers>
<mapper resource="com/cn/mybatis/mapper/taskMapper.xml"/>
<mapper class="com.cn.mybatis.mapper.ITaskMapper"/>
</mappers>

3、创建单元测试类:TestTaskCRUD.class

package com.cn.mybatis.test;

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import com.cn.mybatis.common.MybatisUtil;
import com.cn.mybatis.mapper.ITaskMapper;
import com.cn.mybatis.model.EdiTestTask; public class TestTaskCRUD { @Test
public void testAdd(){
SqlSession ss=MybatisUtil.getSqlSession();
ITaskMapper mapper=ss.getMapper(ITaskMapper.class);
EdiTestTask editt=new EdiTestTask();
editt.setTask_id("");
editt.setTask_name("name");
editt.setTask_owner("owner");
editt.setTask_type("");
int add=mapper.addTask(editt);
ss.commit();
ss.close();
System.out.println("新增行数:"+add);
} @Test
public void testBupdate(){
SqlSession ss=MybatisUtil.getSqlSession(true);
ITaskMapper mapper=ss.getMapper(ITaskMapper.class);
EdiTestTask editt=new EdiTestTask();
editt.setTask_id("");
editt.setTask_name("wangrs2");
editt.setTask_owner("owner2");
editt.setTask_type("");
int update=mapper.updateTask(editt);
ss.close();
System.out.println("更新行数:"+update);
} @Test
public void testCselect() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException{
SqlSession ss=MybatisUtil.getSqlSession();
ITaskMapper mapper=ss.getMapper(ITaskMapper.class);
EdiTestTask editt=mapper.getTaskById("");
if(editt!=null){
Field[] fields=editt.getClass().getDeclaredFields();
for (int i = ; i < fields.length; i++) {
String name=fields[i].getName();
name=name.substring(,).toUpperCase()+name.substring();
String type=fields[i].getGenericType().toString();
Method m=editt.getClass().getMethod("get"+name);
if(type.equals("int")||type.equals("class java.lang.Integer")){
int val=(Integer)m.invoke(editt);
System.out.println("name:"+name+"————value:"+val);
}
if(type.equals("class java.lang.String")){
String value=(String)m.invoke(editt);
System.out.println("name:"+name+"————value:"+value);
}
}
}
} @Test
public void testDel(){
SqlSession ss=MybatisUtil.getSqlSession(true);
ITaskMapper mapper=ss.getMapper(ITaskMapper.class);
String taskId="";
int del=mapper.deleteTask(taskId);
ss.close();
System.out.println("已删除的行数:"+del);
}
}

公用的工具类:MybatisUtil 【获得SQLSession】 代码如下:

package com.cn.mybatis.common;

import java.io.InputStream;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MybatisUtil { public static SqlSessionFactory getSqlSessionFactory(){
String reources="conf.xml";
InputStream is=MybatisUtil.class.getClassLoader().getResourceAsStream(reources);
SqlSessionFactory ssf=new SqlSessionFactoryBuilder().build(is);
return ssf;
} public static SqlSession getSqlSession(){
SqlSession ss=MybatisUtil.getSqlSessionFactory().openSession();
return ss;
} /***
* 获取SQLSession
* @param isAutoCommint
* true:表示创建的SQLSession对象在执行完SQL之后会自动提交事务
* false:表示创建SQLSession对象在执行完SQL之后不会自动提交事务,这时需要我们手动调用sql.commit()来提交事务
* @return
*/
public static SqlSession getSqlSession(boolean isAutoCommint){
return getSqlSessionFactory().openSession(isAutoCommint);
} }

Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】的更多相关文章

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

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

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

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

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

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

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

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4262895.html 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用My ...

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

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

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

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

  7. mybatis学习(二)----对表进行CRUD操作

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

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

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

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

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

随机推荐

  1. Makefile自动生成头文件依赖

    前言 Makefile自动生成头文件依赖是很常用的功能,本文的目的是想尽量详细说明其中的原理和过程. Makefile模板 首先给出一个本人在小项目中常用的Makefile模板,支持自动生成头文件依赖 ...

  2. Constructing Roads

    Constructing Roads Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  3. HDOJ/HDU 1180 诡异的楼梯(经典BFS-详解)

    Problem Description Hogwarts正式开学以后,Harry发现在Hogwarts里,某些楼梯并不是静止不动的,相反,他们每隔一分钟就变动一次方向. 比如下面的例子里,一开始楼梯在 ...

  4. ORM介紹及ORM優點、缺點

      主要內容: 1.ORM的概念 2.為什麽要使用ORM 3.ORM的優缺點 4..Net中有那些ORM產品 5.總結 一.ORM的概念 ORM,即Object-Relational Mapping( ...

  5. Java中static和final的区别

    static是静态修饰关键字,可以修饰变量和程序块以及类方法: 当定义一个static的变量的时候jvm会将将其分配在内存堆上,所有程序对它的引用都会指向这一个地址而不会重新分配内存: 当修饰一个程序 ...

  6. pac 文件使用到的javascript函数

    下面是可用于FindProxyForURL()函数体中的条件函数: 基于主机名的函数: isPlainHostName() dnsDomainIs() localHostOrDomainIs() is ...

  7. HTTPS、SSL与数字证书介绍

    在互联网安全通信方式上,目前用的最多的就是https配合ssl和数字证书来保证传输和认证安全了.本文追本溯源围绕这个模式谈一谈. 名词解释 HTTPS:在HTTP(超文本传输协议)基础上提出的一种安全 ...

  8. solr4.0.0学习(二) 数据库导入clob与blob为索引

    导入clob很简单.但是blob好像没有提供方法,所以改了一下源码,重新编译替换class文件,竟然成功了. 先把配置文件贴上 SCHEMA.XML <?xml version="1. ...

  9. java集合类之TreeMap

    转自:http://blog.csdn.net/chenssy/article/details/26668941 TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的 ...

  10. Razor 语法快速参考

    Razor 语法快速参考   本文引自:http://haacked.com/archive/2011/01/06/razor-syntax-quick-reference.aspx 语法名称 Raz ...