一.使用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. pip3 install requests Cannot open D:\Python35\Scripts\pip3-script.py

    1.问题描述: 使用pip(或pip3)指令安装模块时,出现了Cannot open D:\Python35\Scripts\pip3-script.py的报错信息 2.原因分析: pip安装出错 3 ...

  2. 20170923xlVBA_UpdateClientDetailSQL_Dictionary

    Sub UpdateClientDetailWGQ() Dim Wb As Workbook Dim Sht As Worksheet Dim Rng As Range Dim Arr As Vari ...

  3. [LintCode] Binary Tree Level Order Traversal(二叉树的层次遍历)

    描述 给出一棵二叉树,返回其节点值的层次遍历(逐层从左往右访问) 样例 给一棵二叉树 {3,9,20,#,#,15,7} : 3 / \ 9 20 / \ 15 7 返回他的分层遍历结果: [ [3] ...

  4. Confluence 6 空间的权限是附加的

    空间的权限是附加的.如果一个用户以个人的方式或者以一个用户组成员的方式赋予了权限,Confluence 将会把这些权限合并在一起.  下面是这个概念的示例... Sasha 是 confluence- ...

  5. 反射API(二)

    <?php /** * 需求: * 创建一个类来动态调用Module对象, * 即该类可以自由加载第三方插件并集成进已有的系统,而不需要把第三方的代码硬编码进原有的代码. */ class Pe ...

  6. 【洛谷p1601】A+B Problem(高精)

    高精度加法的思路还是很简单容易理解的 A+B Problem(高精)[传送门] 洛谷算法标签: 附上代码(最近懒得一批) #include<iostream> #include<cs ...

  7. Javascript的常见数据类型以及相应操作

    JavaScript概述 1 ECMAScript和JavaScript的关系 1996年11月,JavaScript的创造者--Netscape公司,决定将JavaScript提交给国际标准化组织E ...

  8. 『TensorFlow』第十一弹_队列&多线程&TFRecod文件_我辈当高歌

    TF数据读取队列机制详解 一.TFR文件多线程队列读写操作 TFRecod文件写入操作 import tensorflow as tf def _int64_feature(value): # val ...

  9. shiro身份验证

    身份验证,即在应用中谁能证明他就是他本人.一般提供如他们的身份ID一些标识信息来表明他就是他本人,如提供身份证,用户名/密码来证明. 在shiro中,用户需要提供principals (身份)和cre ...

  10. javaee登录界面

    首先在此之前我们应该正确安装数据库,以及eclipse(javaee)文件包. 1.首先在javaee中建立新的项目 2.右键点击WebContent-New-JSP File,新建jsp(动态)文件 ...