使用 MyBatis 对表执行 CRUD 操作
说明:
1、CRUD: C -- create R -- read U -- update D -- delete
2、Mybatis 的 SQL 核心配置文件中 SQL 语句的参数的传递使用 #{...}
3、以用户表为例讲解 CRUD 操作
1、定义 UserMapper 接口
UserMapper.java 文件的内容如下:
package cn.mybatis.dao; import java.util.List;
import org.apache.ibatis.annotations.Param;
import cn.mybatis.pojo.User; public interface UserMapper { /**
* 查询用户表记录数
* @return
*/
public int count(); /**
* 查询用户表所有用户
* @return
*/
public List<User> findAllUser(); /**
* 单条件查询:根据用户名称查询用户列表(模糊查询)
* @param userName 用户名称
* @return
*/
public List<User> getUserListByUserName(String userName); /**
* 多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:对象入参)
* @param user 对象入参
* @return
*/
public List<User> getUserListByUserNameAndUserRole(User user); /**
* 添加操作:实现向用户表添加用户
* @param user 对象入参
* @return
*/
public int addUser(User user); /**
* 修改操作:实现根据用户 id 修改用户信息的操作
* @param user 对象入参
* @return
*/
public int update(User user); /**
* 修改操作:实现根据用户 id 修改用户密码(使用 @param 注解实现)
* @param id
* @param pwd
* @return
*/
public int updatePwd(@Param("id")Integer id,@Param("userPwd")String pwd); /**
* 删除操作:实现根据用户 id 删除用户的操作
* @param id 用户 id
* @return
*/
public int delete(Integer id);
}
2、定义 sql 映射文件(.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"> <mapper namespace="cn.mybatis.dao.UserMapper"> <!-- MyBatis 实现查询操作,使用的是 select 元素来映射插入语句 --> <!-- 查询用户表记录数 (*/0/1)-->
<select id="count" resultType="int">
select count(1) as count from smbms_user
</select> <!-- 查询用户表所有用户 -->
<select id="findAllUser" resultType="user">
select * from smbms_user
</select> <!--单条件查询:根据用户名称查询用户列表(模糊查询); 参数传递:#{参数名}-->
<select id="getUserListByUserName" resultType="user" parameterType="string">
SELECT * FROM smbms_user WHERE userName LIKE CONCAT('%',#{userName},'%')
</select> <!--多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表(参数:对象入参); 参数传递:#{属性名}(参数对象中的属性名) -->
<select id="getUserListByUserNameAndUserRole" resultType="user" parameterType="user">
SELECT * FROM smbms_user WHERE userName LIKE CONCAT('%',#{userName},'%') AND userRole=#{userRole}
</select> <!--
1、MyBatis 实现增加操作,使用的是 insert 元素来映射插入语句
2、添加操作:实现向用户表添加用户; 参数传递:#{属性名}(参数对象中的属性名)
-->
<insert id="addUser" parameterType="user">
INSERT INTO `smbms_user` (`userCode`,`userName`,`userPassword`,`gender`,`birthday`,`phone`,`address`,`userRole`,`createdBy`,`creationDate`)
VALUES (#{userCode},#{userName},#{userPassword},#{gender},#{birthday},#{phone},#{address},#{userRole},#{createdBy},#{creationDate})
</insert> <!--
1、MyBatis 实现修改操作:使用的是 update 元素来映射修改语句
2、修改操作:实现根据用户 id 修改用户信息的操作 ; 参数传递:#{属性名}(参数对象中的属性名)
-->
<update id="update" parameterType="user">
UPDATE `smbms_user`
SET `userCode`=#{userCode},`userName`=#{userName},`userPassword`=#{userPassword},
`gender`=#{gender},`birthday`=#{birthday},`phone`=#{phone},`address`=#{address},
`userRole`=#{userRole},`modifyBy`=#{modifyBy},`modifyDate`=#{modifyDate}
where id=#{id}
</update> <!--修改操作:实现根据用户 id 修改用户密码(使用 @param 注解实现)-->
<update id="updatePwd">
UPDATE `smbms_user` SET userPassword=#{userPwd} WHERE id=#{id}
</update> <!--
1、MyBatis 实现删除操作,是使用 delete 元素来映射删除语句
2、删除操作:实现根据用户 id 删除用户的操作
-->
<delete id="delete" parameterType="integer">
DELETE FROM `smbms_user` WHERE id=#{id}
</delete>
</mapper>
3、编写单元测试类
UserMapperTest.java 文件的内容如下:
package cn.mybatis.test; import java.text.SimpleDateFormat;
import java.text.ParseException;
import java.util.Date;
import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.junit.After;
import org.junit.Before;
import org.junit.Test; import cn.mybatis.dao.UserMapper;
import cn.mybatis.pojo.User;
import cn.mybatis.util.MyBatisUtil; public class UserMapperTest { SqlSession session = null; @Test // 测试获取 session
public void test() {
System.err.println(MyBatisUtil.getSqlSession());
} @Before // 每次执行 @Test 方法之前会执行这个方法
public void initSession() {
session = MyBatisUtil.getSqlSession();
} @After // 每次执行 @Test 方法之后会执行这个方法
public void closeSession() {
MyBatisUtil.close(session);
} @Test // 测试查询用户表记录数
public void testCount() {
int count = 0;
count = session.getMapper(UserMapper.class).count();
System.out.println(count);
} @Test // 测试查询用户表所有用户
public void testFindAllUser() {
List<User> userList = null;
userList = session.getMapper(UserMapper.class).findAllUser();
for (User user : userList) {
System.out.println(user);
}
} @Test // 测试根据用户名称查询用户列表(模糊查询)
public void testGetUserListByUserName() {
List<User> userList = null;
String userName = "李";
userList = session.getMapper(UserMapper.class).getUserListByUserName(userName);
for (User user : userList) {
System.out.println(user);
}
} @Test // 测试多条件查询:根据用户名称(模糊查询)和用户角色查询用户列表
public void testGetUserListByUserNameAndUserRole() {
List<User> userList = null;
User user = new User();
user.setUserName("孙");
user.setUserRole(3);
userList = session.getMapper(UserMapper.class).getUserListByUserNameAndUserRole(user);
for (User u : userList) {
System.out.println(u);
}
} @Test // 测试添加操作:实现向用户表添加用户
public void testAddUser() {
int count = 0;// 返回执行 SQL 影响的行数
try {
User user = new User();
user.setUserCode("weixin");
user.setUserName("魏子轩");
user.setUserPassword("123456");
Date birthday;
birthday = new SimpleDateFormat("yyyy-MM-dd").parse("1997-08-15");
user.setBirthday(birthday);
user.setAddress("深圳市南山区南头古城");
user.setGender(20);
user.setPhone("18926477245");
user.setUserRole(1);
user.setCreatedBy(1);
user.setCreationDate(new Date());
count = session.getMapper(UserMapper.class).addUser(user);
// 模拟异常,进行回滚
// int i=2/0;
session.commit(); // 提交事务(MyBatisUtil 中设置了不自动提交事务,因此手动提交)
} catch (ParseException e) {
e.printStackTrace();
session.rollback();// 发生异常就回滚
count = 0;
}
System.out.println(count);
} @Test // 测试修改操作:实现根据用户 id 修改用户信息的操作
public void testUpdate() {
int count = 0;// 返回执行 SQL 影响的行数
try {
User user = new User();
user.setId(16);
user.setUserCode("liuxinxin");
user.setUserName("刘鑫鑫");
user.setUserPassword("123456");
Date birthday = new SimpleDateFormat("yyyy-MM-dd").parse("1996-08-15");
user.setBirthday(birthday);
user.setAddress("江西南昌");
user.setGender(2);
user.setPhone("13340090067");
user.setUserRole(2);
user.setModifyBy(1);
user.setModifyDate(new Date());
count = session.getMapper(UserMapper.class).update(user);
// 模拟异常,进行回滚
// int i=2/0;
session.commit(); // 提交事务(MyBatisUtil 中设置了不自动提交事务,因此手动提交)
} catch (ParseException e) {
e.printStackTrace();
session.rollback();// 发生异常就回滚
count = 0;
}
System.out.println(count);
} @Test // 测试修改操作:实现根据用户 id 修改用户密码(使用 @param 注解实现)
public void updatePwd() {
int count = 0;// 返回执行 SQL 影响的行数
Integer id = 1;
String pwd = "123456";
count = session.getMapper(UserMapper.class).updatePwd(id, pwd);
session.commit(); // 提交事务(MyBatisUtil 中设置了不自动提交事务,因此手动提交)
System.out.println(count);
} @Test // 测试删除操作:实现根据用户 id 删除用户的操作
public void testDelete() {
int count = 0; // 返回执行 SQL 影响的行数
try {
Integer id = 16;
count = session.getMapper(UserMapper.class).delete(id);
session.commit(); // 提交事务(MyBatisUtil 中设置了不自动提交事务,因此手动提交)
} catch (Exception e) {
e.printStackTrace();
session.rollback();// 发生异常就回滚
count = 0;
}
System.out.println(count);
}
}
注意点
1、为了使数据库查询的结果和返回类型中的属性能够自动匹配以便开发,对于 MySQL 数据库和 JavaBean 都会采用同一套命名规则,即 Java 命名驼峰规则,这样就不需要再做映射(注:数据库表的字段名和属性名不一致的情况下需要手动映射)。注意参数的传递使用 #{ 参数名 },它告诉 MyBatis 生成 PreparedStatement 参数。
2、MyBatis 传入参数类型可以是 Java 基础数据类型,但是只适用于一个参数的情况,通过 {参数名}即可获取传入的值。若是多参数入参,需要复杂数据类型来支持,包括 Java 实体类、Map,通过#{属性名}或#{Map的key}来获取传入的参数值。
3、对于增删改(insert,update,delete)这类数据库更新操作,需要注意两点:
(1)该类型的操作本身默认返回执行 SQL 影响的行数,所以 DAO 层的接口方法的返回值一般设置为 int 类型。最好不要返回 boolean 类型。
(2) insert、update、delete 元素中均没有 resultType 属性,只有查询操作需要对返回结果类型( resultType / resultMap )进行相应的指定。
使用 MyBatis 对表执行 CRUD 操作的更多相关文章
- 使用MyBatis对表执行CRUD操作
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)
本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...
- MyBatis入门学习教程-使用MyBatis对表执行CRUD操作
上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...
- MyBatis学习总结_02_使用MyBatis对表执行CRUD操作
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...
- 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
[转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...
- 【Mybatis】MyBatis对表执行CRUD操作(三)
本例在[Mybatis]MyBatis配置文件的使用(二)基础上继续学习对表执行CRUD操作 使用MyBatis对表执行CRUD操作 1.定义sql映射xml文件(EmployeeMapper.xml ...
- MyBatis学习笔记(二)——使用MyBatis对表执行CRUD操作
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4262895.html 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用My ...
- 二:MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...
随机推荐
- ANT-普通替换和正则替换
ant提供了两个指令用于编译时修改文件,好处就不说了 ,就说说如何使用吧. replaceregexp 和 replace的区别就和java中String replace和replaceAll一样 , ...
- FastText 分析与实践
一. 前言 自然语言处理(NLP)是机器学习,人工智能中的一个重要领域.文本表达是 NLP中的基础技术,文本分类则是 NLP 的重要应用.在 2016 年, Facebook Research 开源了 ...
- bzoj2521
最小生成树+最小割 ...我太zz了,没看出来全体减1是一个加1,看见后就是sb题了... 我们发现根据克鲁斯卡尔的过程,我们把边从小到大加入,如果两点已经相连就跳过,那么我们把所有小于等于这条边的边 ...
- LR(逻辑回归)
逻辑回归(Logistic regression): 想要理解LR,只需要记住: Sigmoid 函数: y=1/(1+e-z) 线性回归模型: y=wTx+b 最后: y= 1/(1+e-(wTx+ ...
- asp.net 4.0 尚未在服务商注册 您需要手动将web服务器配置为 ASP.NET4.0,这样您的网站才能正常进行。
VS2010打开项目出现的此问题 电脑先安装VS2010 然后安装VS2010 SP1补丁.然后安装VS2015 后来又安装了Framework4.6.1 用网上搜索到的平常方法无法解决此问题. 最后 ...
- bzoj 2091: [Poi2010]The Minima Game【博弈论+贪心+dp】
不知道算不算博弈 很妙的贪心,一直在想SG函数结果... 首先从大到小排个序,然后考虑当前的人要怎么选:如果不选最后一段,那么另一人会选,这样不利于当前的人,所以每个人一定会选最后一段 设f[i]为要 ...
- 关于ListView的注意点
解决ListView的一些常见问题: 1.listview在拖动的时候背景图片消失变成黑色背景,等到拖动完毕我们自己的背景图片才显示出来 解决:在XML中加入 android:scrollingCac ...
- nginx connect failed (110- Connection timed out) 问题排查
首先排查 ping 下 nginx 与代理服务是否ping 的通,带端口的,telnet 下端口号是否是通的,本次遇到问题为 telnet 发现有台服务器不通,原因是端口未开放
- 22 C#中的异常处理入门 try catch throw
软件运行过程中,如果出现了软件正常运行不应该出现的情况,软件就出现了异常.这时候我们需要去处理这些异常.或者让程序终止,避免出现更严重的错误.或者提示用户进行某些更改让程序可以继续运行下去. C#编程 ...
- 专题八:P2P编程
引言: 前面的介绍专题中有朋友向我留言说介绍下关于P2P相关的内容的,首先本人对于C#网络编程也不是什么大牛,因为能力的关系,也只能把自己的一些学习过程和自己的一些学习过程中的理解和大家分享下的,下面 ...