上一篇讲述了MyBatis的快速入门,下面在此基础上进行增删改查的操作:

首先定义dao层的接口:

package com.zy.dao;

import com.zy.domain.User;

import java.util.List;

public interface UserDao {
/**
* 根据id查询用户信息
*/
public User getUserById(int id); /**
* 查询所有用户信息
*/
public List<User> getUserList(); /**
* 添加用户信息
*/
public void addUser(User user); /**
* 修改用户信息
*/
public void updateUser(User user); /**
* 根据id删除用户信息
*/
public void deleteUser(int id);
}

然后编写UserMapper中的sql语句:

<?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">
<!--
定义所有用到的sql语句 和 映射关系
namespace : 当前这个配置文件的唯一标识, 自定义, 但是不能和其他配置文件namespace重复
-->
<mapper namespace="userMapper">
<!--
定义一条sql语句, 其实就是一个 statement
select 代表是查询语句, 与其类似的还有 insert, update, delete等
id : 这条sql语句的唯一标识,自定义,但是不能和其他sql语句重复
parameterType: sql语句需要的参数类型, 需要写 类的全路径
resultType: sql语句返回的结果类型
-->
<select id="getUserById" parameterType="int" resultType="com.zy.domain.User">
<!--这里写具体的sql语句, #{}是占位符, 编译时会被替换成?, 然后注入真实参数-->
select * from user where id=#{id}
</select>
<!--查询所有用户信息-->
<select id="getUserList" resultType="com.zy.domain.User">
select * from user
</select>
<!--添加用户信息-->
<insert id="addUser" parameterType="com.zy.domain.User">
insert into user (id,name,age) values (null,#{name},#{age})
</insert>
<!--修改用户信息-->
<update id="updateUser" parameterType="com.zy.domain.User">
update user set name=#{name}, age=#{age} where id=#{id}
</update>
<!--删除用户信息-->
<delete id="deleteUser" parameterType="int">
delete from user where id=#{id}
</delete>
</mapper>

说一下新增User返回id的写法:

    <!--
useGeneratedKeys : 是否开启自增主键的回显功能
keyProperty: 对应javabean的属性名
keyColumn : 对应数据库的列名
-->
<insert id="addUser" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
insert into users values(null,#{username},#{age})
</insert>

最后编写接口实现类:

package com.zy.dao;

import com.zy.domain.User;
import org.apache.ibatis.session.SqlSession; import java.util.List; public class UserDaoImpl implements UserDao { private SqlSession sqlSession; //构造函数内传进来一个sqlsession
public UserDaoImpl(SqlSession sqlSession) {
this.sqlSession = sqlSession;
} @Override
public User getUserById(int id) {
return sqlSession.selectOne("userMapper.getUserById", id);
} @Override
public List<User> getUserList() {
return sqlSession.selectList("userMapper.getUserList");
} @Override
public void addUser(User user) {
sqlSession.insert("userMapper.addUser", user);
} @Override
public void updateUser(User user) {
sqlSession.update("userMapper.updateUser", user);
} @Override
public void deleteUser(int id) {
sqlSession.delete("userMapper.deleteUser", id);
}
}

生成UserDao接口的单元测试:

package com.zy.dao;

import com.zy.domain.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test; import java.io.InputStream;
import java.util.List; import static org.junit.Assert.*; public class UserDaoTest {
UserDao dao; @Before
public void setUp() throws Exception {
String resource = "mybatis-config.xml";
InputStream inputStream = UserDaoTest.class.getClassLoader().getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
dao = new UserDaoImpl(sqlSession);
} @Test
public void getUserById() throws Exception {
User user = dao.getUserById(1);
System.out.println(user);
} @Test
public void getUserList() throws Exception {
List<User> list = dao.getUserList();
for (User user : list) {
System.out.println(user);
}
} @Test
public void addUser() throws Exception {
User user = new User();
user.setName("张学友");
user.setAge(18);
dao.addUser(user);
} @Test
public void updateUser() throws Exception {
//先查
User user = dao.getUserById(2);
//后改
user.setName("刘德华");
user.setAge(17);
dao.updateUser(user);
} @Test
public void deleteUser() throws Exception {
dao.deleteUser(1);
} }

然后运行单元测试即可。

附上最终的项目结构图:

MyBatis总结二:增删改查的更多相关文章

  1. mybatis入门(二):增删改查

    mybatis的原理: 1.mybatis是一个持久层框架,是apache下的顶级项目 mybatis托管到googlecode下,目前托管到了github下面 2.mybatis可以将向prepar ...

  2. mybatis入门二-----增删改查

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

  3. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  4. MyBatis简单的增删改查以及简单的分页查询实现

    MyBatis简单的增删改查以及简单的分页查询实现 <? xml version="1.0" encoding="UTF-8"? > <!DO ...

  5. Mybatis入门之增删改查

    Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...

  6. MyBatis -- 对表进行增删改查(基于注解的实现)

    1.MyBatis对数据库表进行增/删/改/查 前一篇使用基于XML的方式实现对数据库的增/删/改/查 以下我们来看怎么使用注解的方式实现对数据库表的增/删/改/查 1.1  首先须要定义映射sql的 ...

  7. Spring Boot 使用Mybatis注解开发增删改查

    使用逆向工程是遇到的错误 错误描述 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): c ...

  8. Mybatis实现简单增删改查

    Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...

  9. SpringMVC,MyBatis商品的增删改查

    一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...

  10. mybatis中的增删改查操作

    在这一个部分,主要进行增删改查的示例书写. 增删改查可以基于xml的,也可以基于注解的方式. 一:对单条数据的查询 1.目录结构 这个使得目录更加清晰 2.User.java 这个使用以前的user表 ...

随机推荐

  1. decimal与 float的区别

      decimal 数据类型最多可存储 38 个数字,所有数字都能够放到小数点的右边.decimal 数据类型存储了一个准确(精确)的数字表达法:不存储值的近似值. 定义 decimal 的列.变量和 ...

  2. 有关linux下redis overcommit_memory的问题,有需要的朋友可以参考下。

    我在安装redis-4.0.6后,启动时出现一些问题,如下: :M Jan ::! Background save may fail under low memory condition. To fi ...

  3. socket和多线程编程资料汇集-基础篇

    0 基础 CS结构的分析,server端和client的选取. 1 查看端口是否链接 netstat -an|grep portid 2 root用户抓包 tcpdump port -w fn.cap ...

  4. bzoj 3681 Arietta

    一棵有根树,每个点有一个音高,有 $m$ 中弹奏方法,每种方法可以弹奏 $d$ 子树中音高在 $[l,r]$ 间的音符,每种方法最多弹 $t$ 次 求最多能弹出多少个音符 $n \leq 10000$ ...

  5. Python之高级库socketserver

    socket并不能多并发,只能支持一个用户,socketserver 简化了编写网络服务程序的任务,socketserver是socket的在封装.socketserver在python2中为Sock ...

  6. [TopCoder12727]FoxAndCity

    vjudge 题意 你有一张\(n\)点的无向图,每个点有一个点权\(w_i\).图中原来存在一些边,你可以任意给这张图加上一些边. 记点\(i\)到点\(1\)的距离为\(d_i\),你需要最小化\ ...

  7. Weblogic-unable to get file lock, will retry …问题解决

    weblogic部署应用出现如下报错: <2017-8-15 下午05时08分44秒 CST> <Info> <Management> <BEA-141281 ...

  8. centos安装yum源

    网易(163)yum源是国内最好的yum源之一 ,无论是速度还是软件版本,都非常的不错,将yum源设置为163yum,可以提升软件包安装和更新的速度,同时避免一些常见软件版本无法找到.具体设置方法如下 ...

  9. MySQL 用户权限详细汇总(转)

    1,MySQL权限体系 MySQL 的权限体系大致分为5个层级: 全局层级: 全局权限适用于一个给定服务器中的所有数据库.这些权限存储在mysql.user表中.GRANT ALL ON .和REVO ...

  10. phpstorm win/mac git配置 破解

    http://blog.csdn.net/fenglailea/article/details/53350080 phpstorm中git配置教程: http://blog.csdn.net/knig ...