一.使用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. Spring Boot之默认连接池配置策略

    注意:如果我们使用spring-boot-starter-jdbc 或 spring-boot-starter-data-jpa “starters”坐标,Spring Boot将自动配置Hikari ...

  2. oracle 查看被锁表 及解除锁定

    查看 哪些表 被锁了 SELECT object_name, machine, s.sid, s.serial# FROM gv$locked_object l, dba_objects o, gv$ ...

  3. Android Error:Could not find lottie.jar

    Android Error:Could not find lottie.jar 今天遇到了一个及其头疼的问题 同事的工程导到我的电脑里却报错,错误是找不到jcenter仓库里的lottie.jar包 ...

  4. 纯js无缝滚动

    HTML代码 <!--父容器要使用overflow: hidden;--> <div id="imgsList" style="height:150px ...

  5. drf 生成接口文档

    REST framework可以自动帮助我们生成接口文档.接口文档以网页的方式呈现. 自动接口文档能生成的是继承自APIView及其子类的视图. 一.安装依赖 REST framewrok生成接口文档 ...

  6. vm15安装MACOS

    VMWare15 安装 Mac OS 系统文章目录VMWare15 安装 Mac OS 系统安装环境工具准备准备工作MAC虚拟机设置启动MAC前准备工作安装系统安装VMware Tool注意事项参考链 ...

  7. vue 监听store中的数值

      computed: {   isFollow () {     return this.$store.state.demo.id; //需要监听的数据   } }, watch: {   isFo ...

  8. 安卓——implements——OnClickListener

    //实现底部的按钮激活监听 设置不同src class click implements OnClickListener{ @Override public void onClick(View v) ...

  9. hdu-6397-容斥

    Character Encoding Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Oth ...

  10. jq判断网页是在什么浏览器打开的

    有的时候项目中有需要用户扫描二维码进行页面识别跳转操作的,(类似当前需要先判断是否为手机默认浏览器打开,尤其是微信打开会影响APP包的下载-微信内置的一个拦截,这对Android来说影响有点大),因此 ...