MyBatis对表的增删改查操作

        主要有两种方式:基于XML实现和基于注解实现。

完整项目结构:

工具类:MyBatisUtil-------用于获取  sqlsession

 package me.gacl.test;

 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 { /**
* 获取SqlSessionFactory
* @return SqlSessionFactory
*/ public static SqlSessionFactory getSqlSessionFactory(){
String resource = "conf.xml";
InputStream is = MyBatisUtil.class.getResourceAsStream(resource);
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
return factory;
} /**
* 获取SqlSession
* @return SqlSesstion
* @throws
*/
public static SqlSession getSqlSession(){
return getSqlSessionFactory().openSession();
} /**
* 获取SqlSession
* @param isAutoCommit
* true 表示创建的SqlSession对象在执行完SQL之后会自动提交事务
* false 表示创建的SqlSession对象在执行完SQL之后不会自动提交事务,这时就需要我们手动调用sqlSession.commit()提交事务
* @return SqlSession
*/
public static SqlSession getSqlSession(boolean isAutoCommit){
return getSqlSessionFactory().openSession(isAutoCommit);
}
}

  一、基于XML实现:(新建方法)

          思路总结:

在 userMapper.xml 文件中进行增删改查实现,

在测试类中映射xml文件中的sql(包名.文件名前缀.方法id): String statement = "me.gacl.mapping.userMapper.addUser";

当新增成功,返回的retResult为1:int retResult = sqlSession.insert(statement,user);

代码实现:

           conf.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>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<!-- 配置数据库连接信息 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
<property name="username" value="root" />
<property name="password" value="liyangkun123" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource = "me/gacl/mapping/userMapper.xml" ></mapper>
</mappers> </configuration>

         数据库驱动:<property name="driver" value="com.mysql.jdbc.Driver" />       

         <mapper   />==<mapper></mapper>

        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"> <!-- 为这个mapper指定一个唯一的namespace,namespace的值习惯上设置成包名+sql映射文件名,这样就能够保证namespace的值是唯一的
例如namespace="me.gacl.mapping.userMapper"就是me.gacl.mapping(包名)+userMapper(userMapper.xml文件去除后缀)--> <mapper namespace="me.gacl.mapping.userMapper"> <!-- 在select标签中编写查询的SQL语句, 设置select标签的id属性为getUser,id属性值必须是唯一的,不能够重复使用parameterType属性指明查询时
使用的参数类型,resultType属性指明查询返回的结果集类型resultType="me.gacl.domain.User"就表示将查询结果封装成一个User类的对象返回
User类就是users表所对应的实体类--> <!-- 根据id查询得到一个user对象 -->
<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> <!-- 修改用户(Update) -->
<update id="updateUser" parameterType="me.gacl.domain.User">
update users set name=#{name},age=#{age} where id=#{id}
</update> <!-- 删除用户(Delete) -->
<delete id="deleteUser" parameterType="int">
delete from users where id=#{id}
</delete> <!-- 查询所有用户 -->
<select id="getAllUsers" resultType="me.gacl.domain.User">
insert * from users
</select> </mapper>

           测试类:TestCRUDByXmlMapper----单元测试验证

 package me.gacl.test;

 import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import me.gacl.domain.User; public class TestCRUDByXmlMapper { @Test
public void testAdd(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
String statement = "me.gacl.mapping.userMapper.addUser";
User user = new User();
user.setName("用户孤傲苍狼");
user.setAge(20); int retResult = sqlSession.insert(statement, user);
sqlSession.close();
System.out.println(retResult);
} @Test
public void testUpdate(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
String statement = "me.gacl.mapping.userMapper.updateUser";
User user = new User();
user.setId(2);
user.setName("zhu");
user.setAge(25); int retResult = sqlSession.update(statement, user);
sqlSession.close();
System.out.println(retResult);
} @Test
public void testdeleteUser(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
String statement = "me.gacl.mapping.userMapper.deleteUser"; int retResult =sqlSession.delete(statement,1);
sqlSession.close();
System.out.println(retResult);
}
}

SqlSession sqlSession = MyBatisUtil.getSqlSession(true);//获取session(内有链接数据库的配置),连上数据库,才能进行操作。

   二、基于注解实现:(新建方法)

写一个接口类定义sql映射,并且我们不用写接口实现,而是由MyBatis动态构建,我们只需要直接拿来使用即可。

接下来将接口类注册到配置文件中(conf.xml) :

借鉴大神代码:

<!-- 注册UserMapper映射接口-->
          <mapper class="me.gacl.mapping.UserMapperI"/>

下一步测试类测试:

注意在新增之前要获得 sqlsession并且open,操作之后要close。

创建接口实例,

获取操作对象,修改操作信息

然后调用增删改查方法执行(借用大神代码)

代码实现:

         UserMapper.java----增删改查接口

 package me.gacl.mapping;

 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 me.gacl.domain.User; public interface UserMapperI { @Insert("insert into users(name,age) value(#{name},#{age})")
public int add(User user); @Delete("delete from users where id=#{id}")
public int deleteById(int id); @Select("select * from users where id=#{id}")
public User selectById(int id); @Update("update users set name=#{name},age=#{age} where id=#{id}")
public int updateById(User user); @Select("select * from users")
public List<User> getAll();
}

         注册到conf.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>
<!-- 引用db.properties配置文件 -->
<properties resource="me/gacl/test/db.properties" /> <environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<!-- 配置数据库连接信息 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
<property name="username" value="root" />
<property name="password" value="liyangkun123" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource = "me/gacl/mapping/userMapper.xml" ></mapper>
<mapper class="me.gacl.mapping.UserMapperI" />
</mappers> </configuration>

         resource和class为包+名完整路径          

        TestCRUDByAnnotationMapper.java------测试类

 package me.gacl.test;

 import java.util.List;

 import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import me.gacl.domain.User;
import me.gacl.mapping.UserMapperI;
import me.gacl.test.MyBatisUtil; public class TestCRUDByAnnotationMapper { @Test
public void testAdd(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
User user = new User();
user.setName("用户xdp");
user.setAge(29);
int add = mapper.add(user); sqlSession.close();
System.out.println(add);
} @Test
public void testDelete(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
int delete = mapper.deleteById(1);
sqlSession.close();
System.out.println(delete);
} @Test
public void testUpdate(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
User user = new User();
user.setId(2);
user.setName("Linda");
user.setAge(23); int update = mapper.updateById(user);
sqlSession.close();
System.out.println(update);
} @Test
public void testSelect(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
User user = mapper.selectById(2);
sqlSession.close();
System.out.println(user); } @Test
public void testSelectAll(){
SqlSession sqlSession = MyBatisUtil.getSqlSession(true);
UserMapperI mapper = sqlSession.getMapper(UserMapperI.class);
List<User> user = mapper.getAll(); sqlSession.close();
System.out.println(user); }
}

注意事项:MyBatisUtil.java,conf.xml, 放到 util 包中时,调用出错,放到同一个包中,没有问题。

大神总结链接:http://www.cnblogs.com/xdp-gacl/p/4262895.html

学习大神笔记之“MyBatis学习总结(二)”的更多相关文章

  1. 学习大神笔记之 “MyBatis学习总结(一)”

    1.准备工作 软件:eclipse. mysql .navicat for mysql 包:mybatis-3.1.1.jar   mysql-connector-java-5.1.7-bin.jar ...

  2. 学习大神笔记之“MyBatis学习总结(三)”

    一.连接数据库的配置单独放在一个properties文件中          创建db.peoperties----保存数据库配置信息      driver=com.mysql.jdbc.Drive ...

  3. 设计模式--单例模式(学习Learning hard大神笔记实践)

    根据大神博客园中的文章,自己亲手敲了一遍,对每个解说点都自己动手进行实践,收获颇丰,谢谢Learning hard大神,原文地址http://www.cnblogs.com/zhili/p/Desig ...

  4. Spring学习笔记:Spring整合Mybatis学习PPT(三:整合思路)

    三.Spring-Mybatis的整合思路

  5. Mybatis学习笔记导航

    Mybatis小白快速入门 简介 本人是一个Java学习者,最近才开始在博客园上分享自己的学习经验,同时帮助那些想要学习的uu们,相关学习视频在小破站的狂神说,狂神真的是我学习到现在觉得最GAN的老师 ...

  6. (原创)mybatis学习一,夯实基础

    一,what?(是什么) MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可 ...

  7. MyBatis学习--简单的增删改查

    jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...

  8. Mybatis学习笔记一

    Mybatis介绍 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为M ...

  9. Mybatis学习笔记之一(环境搭建和入门案例介绍)

    一.Mybatis概述 1.1 Mybatis介绍 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了go ...

随机推荐

  1. 【NopCommerce源码架构学习-二】单例模式实现代码分析

    单例模式是是常用经典十几种设计模式中最简单的..NET中单例模式的实现也有很多种方式.下面我来介绍一下NopCommerce中单例模式实现. 我之前的文章就分析了一下nop中EngineContext ...

  2. Hibernate 更新部分字段的实现

    在Hibernate 中,有时我们只需要更新部分字段,此时如果使用update()方法,会将所有字段都更新,对于没有set的字段,就会设置成NULL,如果这些字段里面有非空的字段就会报错. 解决的方法 ...

  3. luogg_java学习_06_面向对象特性之封装和继承

    这篇博客总结了1天,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 , 因为前不久偶然发现某网站直接复制粘贴我的博客,交谈之后他们修改 ...

  4. 关于Spring/Hibernate 3.x升级4.x的小问题

    情景:   之前版本 现在版本 JDK 1.7 1.8 Tomcat v7.0 v8.0 Spring 3.x 4.x Hibernate 3.x 4.x MySQL 忘了 5.1.53 分析: 如果 ...

  5. springmvc的类型转换

     一.springmvc的类型转换 (一)默认情况下,springmvc内置的类型转换器只能 将"yyyy/MM/dd"类型的字符串转换为Date类型的日期 情境一: 而现在我们无 ...

  6. 不明显的多线程编程的具体Bugs

    我们都知道,在编写多线程程序时,我们应该记住很多细节,比如锁,使用线程安全库等.这里有一个不太明显的bug的列表,特定于多线程程序.其中许多都没有在初学者的文档或教程中提到,但我认为每个使用线程的人最 ...

  7. 新建 ASP.NET Core MVC 项目 -- Hello World!

    一.创建一个空项目 请查看 新建 .NET Core 项目 -- Hello World! 一节,新建一个项目: 二.添加引用并修改配置为 MVC 修改 .vscode\launch.json 文件 ...

  8. [Android]官网《monkeyrunner》中文翻译

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5050768.html 翻译自 Android Develope ...

  9. 深入理解JavaScript的闭包特性如何给循环中的对象添加事件

    初学者经常碰到的,即获取HTML元素集合,循环给元素添加事件.在事件响应函数中(event handler)获取对应的索引.但每次获取的都是最后一次循环的索引.原因是初学者并未理解JavaScript ...

  10. Android自定义控件5--轮播图广告ViewPager基本实现

    本文地址:http://www.cnblogs.com/wuyudong/p/5918021.html,转载请注明源地址. 本文开始实现轮播图广告系列,这篇文章首先实现让图片滑动起来(ViewPage ...