MyBatis之二:简单增删改查
这一篇在上一篇的基础上简单讲解如何进行增删改查操作。
一、在mybatis的配置文件conf.xml中注册xml与注解映射
<!-- 注册映射文件 -->
<mappers>
<!-- 通过xml方式映射 -->
<mapper resource="com/mybatis/crud/userMapper.xml" />
<!-- 通过注解方式映射 -->
<mapper class="com.mybatis.crud.IUserMapper" />
</mappers>
二、在这个com.mybatis.crud包下面新建userMapper.xml文件与IUserMapper接口
1、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="com.mybatis.crud.userMapper"> <insert id="addUser" parameterType="com.mybatis.crud.User">
insert into users(id_id,name_n,age_a) values(#{id},#{name},#{age})
</insert> <delete id="deleteUser" parameterType="int">
delete from users where
id_id=#{id}
</delete> <update id="updateUser" parameterType="com.mybatis.crud.User">
update users set
name_n=#{name},age_a=#{age} where id_id =#{id}
</update> <select id="getAllUsers" resultType="com.mybatis.crud.User"
resultMap="usermap">
select *
from Users
</select> <resultMap type="com.mybatis.crud.User" id="usermap">
<id property="id" column="id_id" />
<result property="name" column="name_n" />
<result property="age" column="age_a" />
</resultMap> <select id="getUser" parameterType="int" resultType="com.mybatis.crud.User"
resultMap="usermap">
select *
from Users where id_id=#{id}
</select>
</mapper>
2、IUserMapper接口定义如下
package com.mybatis.crud; import java.util.List;
import java.util.Properties; import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import org.apache.ibatis.type.JdbcType; public interface IUserMapper { @Insert("insert into users(id_id,name_n,age_a) values(#{id},#{name},#{age})")
public int add(User user); @Delete("delete from users where id_id=#{id}")
public int deleteById(int id); @Update("update users set name_n=#{name},age_a=#{age} where id_id =#{id}")
public int update(User user); @Select("select * from Users where id_id=#{id}")
@Results({
@Result(property = "id", column = "id_id", jdbcType = JdbcType.INTEGER),
@Result(property = "name", column = "name_n", jdbcType = JdbcType.VARCHAR),
@Result(property= "age", column = "age_a", jdbcType = JdbcType.INTEGER) })
public User getById(int id); @Select("select * from Users")
@Results({
@Result(property = "id", column = "id_id", jdbcType = JdbcType.INTEGER),
@Result(property = "name", column = "name_n", jdbcType = JdbcType.VARCHAR),
@Result(property= "age", column = "age_a", jdbcType = JdbcType.INTEGER) })
public List<User> getAll(); }
三、新建一个获取SqlSessionFactory的工具类
package com.mybatis.util; import java.io.InputStream; import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import com.mybatis.demo.test; public class MybatisUtils { public static SqlSessionFactory getFactory(){
String resource = "conf.xml";
InputStream inputStream = test.class.getClassLoader().getResourceAsStream(resource);
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
return sessionFactory;
} }
四、实际测试代码如下
package com.mybatis.crud; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test; import com.mybatis.util.MybatisUtils; public class TestCrud { //方法名称上面F11键 即可运行测试方法 @Test
public void testAdd() {
SqlSessionFactory factory = MybatisUtils.getFactory();
SqlSession session = factory.openSession(true); String statement = "com.mybatis.crud.userMapper.addUser";
User user1 = new User();
user1.setId(199);
user1.setName("wrrrugggcj");
user1.setAge(296);
System.out.println("[xml]新增影响行数:"+session.insert(statement, user1)); User user2 = new User();
user2.setId(198);
user2.setName("wrrrugggcjeee");
user2.setAge(26); IUserMapper userMapper = session.getMapper(IUserMapper.class);
System.out.println("[注解]新增影响行数:"+userMapper.add( user2)); session.close();
} @Test
public void testUpdate() {
SqlSessionFactory factory = MybatisUtils.getFactory();
//默认手动提交
SqlSession session = factory.openSession(); String statement = "com.mybatis.crud.userMapper.updateUser";
User user1 = new User();
user1.setId(199);
user1.setName("199");
user1.setAge(89);
System.out.println("[xml]修改影响行数:"+session.update(statement, user1)); User user2 = new User();
user2.setId(198);
user2.setName("198");
user2.setAge(89);
IUserMapper userMapper = session.getMapper(IUserMapper.class);
System.out.println("[注解]修改影响行数:"+userMapper.update(user2)); //提交
session.commit();
session.close(); } @Test
public void testDelete() {
SqlSessionFactory factory = MybatisUtils.getFactory(); SqlSession session = factory.openSession(true); String statement = "com.mybatis.crud.userMapper.deleteUser";
System.out.println("[xml]删除影响行数:"+session.delete(statement,199)); IUserMapper userMapper = session.getMapper(IUserMapper.class);
System.out.println("[注解]删除影响行数:"+userMapper.deleteById(198)); session.close();
} @Test
public void testGetAllusers() {
SqlSessionFactory factory = MybatisUtils.getFactory(); SqlSession session = factory.openSession(true); String statement = "com.mybatis.crud.userMapper.getAllUsers";
List<User> users = session.selectList(statement);
System.out.println("[xml]查询用户列表:"+users); IUserMapper userMapper = session.getMapper(IUserMapper.class);
System.out.println("[注解]查询用户列表:"+userMapper.getAll()); session.close(); }
}
至此,一个基于mybatis的简单增删改就完成了,不过建议在阅读这篇文章的时候先将入门篇看一遍就可以了。
MyBatis之二:简单增删改查的更多相关文章
- idea+spring4+springmvc+mybatis+maven实现简单增删改查CRUD
在学习spring4+springmvc+mybatis的ssm框架,idea整合简单实现增删改查功能,在这里记录一下. 原文在这里:https://my.oschina.net/finchxu/bl ...
- MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多
一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.D ...
- Mybatis框架二:增删改查
这里是搭建框架和准备数据: http://www.cnblogs.com/xuyiqing/p/8600888.html 实现增删改查功能: 测试类: package junit; import ja ...
- MyBatis总结二:增删改查
上一篇讲述了MyBatis的快速入门,下面在此基础上进行增删改查的操作: 首先定义dao层的接口: package com.zy.dao; import com.zy.domain.User; imp ...
- Mybatis实现简单增删改查
Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...
- Redis:五种数据类型的简单增删改查
Redis简单增删改查例子 例一:字符串的增删改查 #增加一个key为ay_key的值 127.0.0.1:6379> set ay_key "ay" OK #查询ay_ke ...
- ado.net的简单数据库操作(三)——简单增删改查的实际应用
果然,在犯困的时候就该写写博客,写博客就不困了,哈哈! 上篇我记录了自己的SqlHelper的开发过程,今天记录一下如何使用这个sqlhelper书写一个具有简单增删改查的小实例啦. 实例描述:在数据 ...
- Mybatis实现数据的增删改查
Mybatis实现数据的增删改查 1.项目结构(使用maven创建项目) 2.App.java package com.GetcharZp.MyBatisStudy; import java.io.I ...
- 国产化之路-统信UOS + Nginx + Asp.Net MVC + EF Core 3.1 + 达梦DM8实现简单增删改查操作
专题目录 国产化之路-统信UOS操作系统安装 国产化之路-国产操作系统安装.net core 3.1 sdk 国产化之路-安装WEB服务器 国产化之路-安装达梦DM8数据库 国产化之路-统信UOS + ...
随机推荐
- ejabberd、jabber、jabberd、xmpp辨析
Jabber 是著名的即时通讯服务服务器,它是一个自由开源软件,能让用户自己架即时通讯服务器,可以在Internet上应用,也可以在局域网中应用. XMPP(可扩展消息处理现场协议)是基于可扩展 ...
- 微信开发之Ngrok环境准备(一)
一.为什么要使用ngrok? 各位肯定都知道,做微信开发,我们的开发服务器需要和微信服务器做交互,SO,我们需要准备一台放置在公网的服务器,能够使得我们的服务器可以正常访问微信服务器,并且微信服务器也 ...
- HDU 5119 Happy Matt Friends
Happy Matt Friends Time Limit: 6000/6000 MS (Java/Others) Memory Limit: 510000/510000 K (Java/Others ...
- POJ 2549 Sumsets
Sumsets Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10593 Accepted: 2890 Descript ...
- CXF之八 RESTFul服务
JAX-RS概述 JAX-RS是Java提供用于开发RESTful Web服务基于注解(annotation)的API.JAX-RS旨在定义一个统一的规范,使得Java程序员可以使用一套固定的接口来开 ...
- C#控制定位Word光标移动到任意行或者最后一行,取得光标位置等操作
C#控制定位Word光标移动到任意行或者最后一行,取得光标位置等操作 http://blog.csdn.net/jglie/article/details/7394256 十一.上下左右移动光标位 p ...
- Linux基本命令(2)有关磁盘空间的命令
有关磁盘空间的命令 命令 功能 mount 挂载文件系统 umount 卸载已挂载上的文件系统 df 检查各个硬盘分区和已挂上来的文件系统的磁盘空间 du 显示文件目录和大小 fsck 主要是检查和修 ...
- qt 在指定区域添加图片
博客出处:http://www.devdiv.com/thread-39111-1-1.html 折腾了几天,终于实现了图片的淡出淡入的效果. 其实也应该是说实现了图片的淡入效果,因为淡出效果我暂时还 ...
- flex 图片旋转(解决公转和自转问题)
在Flex中图片的旋转是既有公转和自转的.这样在图片旋转的时候就有一定小麻烦: 为了更好地说明问题,先引入两个概念:“自转”和“公转”.想象一下,地球在绕着太阳公转的同时,它自己也在自转.Flash应 ...
- D3D11_USAGE使用
MSDN文档链接:http://msdn.microsoft.com/en-us/library/windows/desktop/ff476259(v=vs.85).aspx 不得不同吐槽一点的是,你 ...