一.使用MyBatis对表执行CRUD操作——基于XML的实现

userMapper.xml映射文件如下:

 <?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">
<!--namespace一般命名成报名+映射名-->
<mapper namespace="me.gacl.mapping.userMapper">
<!--根据id查询-->
<select id="getUser" parameterType="int" resultType="me.gacl.domain.User">
select * from users where id=#{id}
</select>
<!--插入一条记录(Create)-->
<insert id="addUser" parameterType="me.gacl.domain.User">
insert into users(name ,age) values(#{name},#{age})
</insert>
<!--删除一条记录(Drop)-->
<delete id="deleteUser" parameterType="int">
delete from users where id=#{id}
</delete>
<!--更新(Update)-->
<update id="updateUser" parameterType="me.gacl.domain.User">
update users set NAME=#{name},age=#{age} where id=#{id}
</update>
<!--查询全部记录(Retrieve)-->
<select id="getAllUser" resultType="me.gacl.domain.User">
select * from users
</select>
</mapper>

测试类代码如下

 package me.gacl.domain;

 import me.gacl.Util.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;
import java.util.List;
/**
* Created by hu on 2017/8/26.
*/
public class TestCRUDByXMLMapper {
public void testAdd(){
//参数为true,表示事务自动提交,参数为false则需要手动提交
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
//SqlSession sqlSession = MyBatisUtil.getSqlSession(false);
//要插入的user对象
User user = new User();
user.setName("芝麻糊");
user.setAge(17);
//statement是映射sql的标识字符串,me.gacl.mapping.userMapper是userMapper.xml中mapper标签的namespace属性,
// addUser是insert标签的id,通过insert标签的id值可以找到要执行的sql语句
String statement = "me.gacl.mapping.userMapper.addUser";
//执行插入操作
int resultAdd = sqlSession.insert(statement,user);
//手动提交
//sqlSession.commit();
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(resultAdd);
}
public void testUpdate(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
//要更新的user对象
User user = new User();
user.setName("胡图图");
user.setAge(18);
user.setId(3);
//statement是映射sql的标识字符串,me.gacl.mapping.userMapper是userMapper.xml中mapper标签的namespace属性,
//updateUser是update标签的id,通过update标签的id值可以找到要执行的sql语句
String statement = "me.gacl.mapping.userMapper.updateUser";
//执行更新操作
int resultAdd = sqlSession.update(statement,user);
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(resultAdd);
}
public void testDelete(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
//statement是映射sql的标识字符串,me.gacl.mapping.userMapper是userMapper.xml中mapper标签的namespace属性,
// deleteUser是delete标签的id,通过delete标签的id值可以找到要执行的sql语句
String statement = "me.gacl.mapping.userMapper.deleteUser";
//执行删除操作
int resultAdd = sqlSession.delete(statement,2);
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(resultAdd);
}
public void testGetAll(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
//statement是映射sql的标识字符串,me.gacl.mapping.userMapper是userMapper.xml中mapper标签的namespace属性,
// getAllUser是select标签的id,通select标签的id值可以找到要执行的sql语句
String statement = "me.gacl.mapping.userMapper.getAllUser";
//执行查询全部操作
List <User> list = sqlSession.selectList(statement);
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(list);
} public static void main(String[] args) {
TestCRUDByXMLMapper testCRUDByXMLMapper = new TestCRUDByXMLMapper();
testCRUDByXMLMapper.testAdd();
// testCRUDByXMLMapper.testUpdate();
// testCRUDByXMLMapper.testDelete();
// testCRUDByXMLMapper.testGetAll();
}
}

在addTest插入数据库过程中出现中文乱码情况,将mybatis-config.xml中的链接URL加上【?characterEncoding=UTF-8】,则中文正常显示

执行了三次插入操作,如下图有两条乱码记录,最后一条是改了之后的

执行更新操作,结果如下图

执行删除操作,可以看到id=2的记录不见了

执行查询全部操作

二、使用MyBatis对表执行CRUD操作——基于注解的实现

1.定义sql映射的接口UserMapperI

 package me.gacl.map;

 import me.gacl.domain.User;
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 java.util.List; /**
* 定义sql映射的接口,使用注解指明方法执行的SQL.
*/
public interface UserMapperI {
//使用@Insert注解指明add方法要执行的SQL
@Insert("insert into users(name,age) values(#{name},#{age})")
public int add(User user);
//使用@Update注解指明update方法要执行的SQL
@Update("update users set(name=#{name},age=#{age})")
public int update(User user);
//使用@Delete注解指明delete方法要执行的SQL
@Delete("delete from users where id=#{id}")
public int delete(int id);
//使用@Select注解指明getAll方法要执行的SQL
@Select("select * from users")
public List<User> getAll();
}

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

2.然后在mybatis-config.xml中注册这个映射接口

 <?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--配置数据库环境,可以有多个environment,default值是其中一个environment的id值-->
<environments default="developement">
<environment id="developement">
<!--配置事务管理器,JDBC和MANAGED两种,JDBC可以进行回滚和提交-->
<transactionManager type="JDBC"></transactionManager>
<!--配置数据源,type=[UNPOOLED | POOLED| JNDI], POOLED表示实现简单的数据池连接,连接可以复用-->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF-8"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</dataSource>
</environment>
</environments>
<!--resource值是映射文件所在的路径-->
<!--class值是映射接口类所在的路径-->
<mappers>
<mapper resource="mapping/userMapper.xml"></mapper>
<mapper class="me.gacl.map.UserMapperI"></mapper>
</mappers>
</configuration>

3.编写测试类,代码如下:

package me.gacl.domain;

import me.gacl.Util.MyBatisUtil;
import me.gacl.map.UserMapperI;
import org.apache.ibatis.session.SqlSession;
import java.util.List; /**
* Created by huyanxia on 2017/8/26.
*/
public class TestCRUDByAnnotation {
public void testAdd(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI userMapperI = sqlSession.getMapper(UserMapperI.class);
//要插入的user对象
User user = new User();
user.setName("我是注解");
user.setAge(12);
//执行插入操作
int resultAdd = userMapperI.add(user);
//手动提交
//sqlSession.commit();
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(resultAdd);
}
public void testUpdate(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI userMapperI = sqlSession.getMapper(UserMapperI.class);
//要更新的user对象
User user = new User();
user.setName("劳斯莱斯了");
user.setAge(2);
user.setId(5);
//执行更新操作
int resultAdd = userMapperI.update(user);
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(resultAdd);
}
public void testDelete(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI userMapperI = sqlSession.getMapper(UserMapperI.class);
//执行删除操作
int resultAdd = userMapperI.delete(4);
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(resultAdd);
}
public void testGetAll(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI userMapperI = sqlSession.getMapper(UserMapperI.class);
//执行查询全部操作
List<User> list = userMapperI.getAll();
//使用sqlSession执行完后需要关闭sqlSession
sqlSession.close();
System.out.println(list);
} public static void main(String[] args) {
TestCRUDByAnnotation testCRUDByAnnotation = new TestCRUDByAnnotation();
testCRUDByAnnotation.testAdd();
//testCRUDByAnnotation.testUpdate();
//testCRUDByAnnotation.testDelete();
//testCRUDByAnnotation.testGetAll();
}
}

执行结果如下:

插入操作

更新操作

删除操作

查询全部

4.其中用到的MybatisUtil类是自己编写的,用来获取SqlSession

 package me.gacl.Util;

 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 java.io.IOException;
import java.io.Reader; /**
* 获取SqlSession
*/
public class MyBatisUtil {
public static SqlSession getSqlSession(boolean autoCommit){
String resource = "mybatis-config.xml";
try{
Reader reader = Resources.getResourceAsReader(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
SqlSession sqlSession = sqlSessionFactory.openSession(autoCommit);
return sqlSession;
}catch (IOException e){
e.printStackTrace();
}
return null;
}
}

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操作【参考】

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

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

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

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

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

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

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

  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. 20170822xlVBA ExportCellPhone

    Public Sub GetCellPhone() Dim CellPhone As String Dim Arr As Variant Dim Brr As Variant Dim n As Lon ...

  2. android -------- Data Binding的使用 ( 五) include

    Data Binding的中 include 标签的使用 inclune使用和原来一样,但要如何使数据也在 include中使用呢? 先看看我的布局文件 include的布局文件,也要使用 <l ...

  3. Numpy常用API

    目录 一.输入和输出 1.1 NumPy二进制文件(NPY,NPZ) 1.2 文本文件 1.3 正则表达式解析 1.4 原始二进制文件 1.5 内存映射文件 1.6 Base-n相关 1.7 数据源 ...

  4. mac中 hosts地址

    /etc/hosts 拉出hosts文件,修改之后再拉进去

  5. 『TensorFlow』高级高维切片gather_nd

    gather用于高级切片,有关官方文档的介绍,关于维度的说明很是费解,示例也不太直观,这里给出我的解读,示例见下面,     indices = [[0, 0], [1, 1]]    params ...

  6. 『TensorFlow』分布式训练_其三_多机分布式

    本节中的代码大量使用『TensorFlow』分布式训练_其一_逻辑梳理中介绍的概念,是成熟的多机分布式训练样例 一.基本概念 Cluster.Job.task概念:三者可以简单的看成是层次关系,tas ...

  7. windos 开启openssl

    前面我使用的是wampserver百度提示的软件,然后我卸载了,自己重新再官网上下载了一个比较新的版本,然后我按照的时候用默认路径,他的的都不用怎么配置,新版本都给你弄好了. 低版本的要在httped ...

  8. Leetcode 150

    class Solution { public: int evalRPN(vector<string>& tokens) { stack<int> st; ;i < ...

  9. Echarts 简单报表系列四:雷达图

    代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  10. HTML相关知识点总结

    1.表格<table>常用属性 cellspacing:两个单元格之间的距离 注:属性值为数字,效果图如下(左边cellspacing="0",右边cellspacin ...