【Mybatis】02 快速入门Part2 补完CRUD
这是我们的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接口名称-->
<mapper namespace="cn.dai.mapper.UserMapper"> <!-- 我们的SQL语句使用这种标签来实现 -->
<!-- id 是我们的Mapper接口中的 方法名称 -->
<!-- resultType 表示查询的结果类型,因为是List 这里我们直接填写泛型的元素类型就好了 -->
<select id="getUserList" resultType="cn.dai.pojo.User">
/* 这里填写我们的SQL语句 */
SELECT * FROM `user`;
</select> </mapper>
mapper
映射配置文件的根标签,有且只能存在一个
namespace
是我们所绑定的Mapper接口类
select
表示SQL语句的标签,总共是CRUD4种SQL语句标签
即我们的:
SELECT
INSERT
UPDATE
DELETE
id
我们的对应的接口的方法名称
resultType
查询后的结果集类型,是List集合就是我们所泛型的类型
parameterType
参数类型,填写注入SQL的类型即可
DAO的编写流程 ×
Mapper的编写流程 √
1、编写接口
2、编写抽象SQL方法
3、编写接口映射配置文件
4、编写SQL标签
5、回到核心配置注册映射文件
补全我们的DAO接口,口胡是Mapper
public interface UserMapper {
List<User> getUserList();
User getUserById(int id);
int addUser(User user);
int updateUserById(User user);
int deleteUserById(int id);
}
补全映射配置
<?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接口名称-->
<mapper namespace="cn.dai.mapper.UserMapper"> <!-- 我们的SQL语句使用这种标签来实现 -->
<!-- id 是我们的Mapper接口中的 方法名称 -->
<!-- resultType 表示查询的结果类型,因为是List 这里我们直接填写泛型的元素类型就好了 -->
<select id="getUserList" resultType="cn.dai.pojo.User">
/* 这里填写我们的SQL语句 */
SELECT * FROM `user`;
</select> <!-- parameterType="int" 表示参数类型,也就是说我们只能配置1个参数-->
<select id="getUserById" resultType="cn.dai.pojo.User" parameterType="int">
/* #{user_id} 表示预编译SQL注入,普通SQL注入是 ${} 这个里面的user_id是实体类的,不是数据表的 */
SELECT * FROM `user` WHERE `user_id` = #{user_id};
</select> <!-- 增删改都不需要填写结果类型,因为只返回操作的结果记录数 -->
<insert id="addUser" parameterType="cn.dai.pojo.User" >
/* 这里我们设置的自增,所以主键可以不需要设置,注入实例时主键为null即可 */
INSERT
INTO `user`(user_name,user_password)
VALUES(#{user_name},#{user_password});
</insert> <!-- 修改语句-->
<update id="updateUserById" parameterType="cn.dai.pojo.User" >
UPDATE `user`
SET
user_name = #{user_name},
user_password = #{user_password})
WHERE
user_id = #{user_id};
</update> <!-- 删除语句-->
<delete id="deleteUserById" parameterType="int">
DELETE FROM `user`
WHERE user_id = #{user_id};
</delete>
</mapper>
开始测试【核心配置已经注册了】
发现异常问题

我在这里找了很久才发现,Mybatis会将注释中的注入表达式也会读取

我们将 $ 符号和{}区分开来再进行测试
结果还是报错

因为前面的注释的预编译SQL注入也会读取
这个东西也要区分开来

再次测试,访问成功

实际上是这样映射的

我们可以把映射配置的user_id改成id试试
这样还是能被读取到,也就是说基本类型,只要类型一致,
Mybatis如果匹配不了标识符,就会根据类型匹配
只要符合类型,依然能够查询出来,不过最好还是规范书写

剩余的增删改测试
增加 INSERT
如果实体类对应主键类型是基本类型,在注入实体类对象时,这个主键不可为null,必须赋值,
在我们的数据表的主键约束中设置了自增约束,这个情况就很尴尬了
所以为什么要设置实体类的主键类型为包装类了

可以看到我们的操作结果返回了1,说明操作是成功的
但是,查看数据库之后,并没有这个记录,
这是因为Mybatis的事务管理是默认开启的!!!

执行提交
sqlSession.commit();
再次查看结果,成功

如果要关闭事物可以在获取会话对象时,注入参数为true

修改
写错一个字符都有可能不通过

@Test
public void queryOne3(){
// 获取会话对象
SqlSession sqlSession = MybatisUtil.getSqlSession();
// 获得映射实现实例
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
// 调用接口方法
int r = mapper.updateUserById(new User(17,"阿花","332211"));
System.out.println(r);
// 成功再提交,否则无意义
if ( r > 1) sqlSession.commit();
// 释放资源
sqlSession.close();
}
测试成功

删除
@Test
public void queryOne4(){
// 获取会话对象
SqlSession sqlSession = MybatisUtil.getSqlSession();
// 获得映射实现实例
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
// 调用接口方法
int i = mapper.deleteUserById(17);
System.out.println(i);
if ( i > 1) sqlSession.commit();
// 释放资源
sqlSession.close();
}
测试成功

出现的错误总结:
1、SQL语句注释中的注入表达式也会被Mybatis读取,
所以要小心表达式字符
2、参数的标识设置尽可能的规范
演示的这段虽然没有出错,
是因为基本类型Mybatis可以识别匹配,但是要注意!!!
3、Mybatis的事务管理的默认开启的
除了查询,增删改在执行成功的情况下需要提交
4、SQL语句不要写错.
我也是没看仔细
5、注意主键映射的Java数据类型
如果没有在数据表设置自增约束,
Java的映射数据类型,可以基本int也可以包装类
如果是自增列,Java对象注入SQL时可以写null,
int类型也不是不能写,就是主键的编号会打乱【不推荐】
【Mybatis】02 快速入门Part2 补完CRUD的更多相关文章
- Mybatis Plus (特性、快速入门、日志、CRUD)
Mybatis plus 可以节省很多的工作,所有的CRUD JPA yk-mapper Mybatis plus 偷懒的 简介: MyBatis-Plus(opens new window)(简称 ...
- mybatis框架快速入门
通过快速入门示例,我们发现使用mybatis 是非常容易的一件事情,因为只需要编写 Dao 接口并且按照 mybatis要求编写两个配置文件,就可以实现功能.远比我们之前的jdbc方便多了.(我们使用 ...
- MyBatis(1)——快速入门
MyBatis 简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...
- (转) MyBatis(1)——快速入门
MyBatis 简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...
- SpringData JPA快速入门和基本的CRUD操作以及Specifications条件查询
SpringData JPA概述: SpringData JPA 是 Spring 基于 ORM 框架.JPA 规范的基础上封装的一套JPA应用框架,可使开发者用极简的代码即可实现对数据库的访问和操作 ...
- springboot笔记02——快速入门quickstart
前言 学习一个新的框架,往往会用一个quickstart快速入门,这次就写一下springboot的quickstart程序. 开发环境 JDK 1.8 Springboot 2.1.6 Maven ...
- Mysql快速入门(看完这篇能够满足80%的日常开发)
这是一篇mysql的学习笔记,整理结合了网上搜索的教程以及自己看的视频教程,看完这篇能够满足80%的日常开发了. 菜鸟教程:https://www.runoob.com/mysql/mysql-tut ...
- mybatis的快速入门
说明: 在这个部分,会写个简单的入门案例. 然后,会重新写一个,更加严格的程序案例. 一:案例一 1.最终的目录结构 2.新建一个普通的Java项目,并新建lib 在项目名上右键,不是src. 3.导 ...
- spring3.0+mybatis+spring快速入门
一.首先奉上项目目录结构: 说明: dao,mapping,model包下的所有内容可以使用Generator工具自助生成. 具体用法,可以网上学习一下,比较简单,主要做以下工作: 1.提供相关的数据 ...
- MyBatis框架——快速入门
主流的ORM框架(帮助开发者实现数据持久化工作的框架): 1.MyBatis: 半自动化ORM框架,半自动:指框架只完成一部分功能,剩下的工作仍需开发者手动完成. MyBatis 框架没有实现 POJ ...
随机推荐
- 代码审计——基础(JAVAWEB)
JAVAWEB 目录 JAVAWEB Servlet技术 JavaWeb概述 Servelt与Servlet容器 Servlet概念 Tomcat Web程序结构 Servlet容器响应客户请求的过程 ...
- [SWPUCTF 2021 新生赛]include
打开我们可以看到让我们传入一个file,会出现一串代码,我们去分析一下: 当看到ini_set("allow_url_include","on");设置为on, ...
- kettle从入门到精通 第五十三课 ETL之kettle MQTT/RabbitMQ consumer实战
1.上一节课我们学习了MQTT producer 生产者步骤,MQTT consumer消费者步骤.该步骤可以从支持MRQTT协议的中间件获取数据,该步骤和kafka consumer 一样可以处理实 ...
- SpringBoot系列(四)使用spring-kafka实现生产者消费者demo代码
一.引入spring-kafka的maven依赖 <dependency> <groupId>org.springframework.kafka</groupId> ...
- edge 书签栏 收藏夹栏 字体大小
WIN10中,edge收藏夹栏字体太大,如果收藏数目多,得多翻好几页. 解决方法: 地址栏中输入: edge://flags/#edge-pc-ui-integration Enable Window ...
- 【译】Visual Studio 17.10 发布了新版扩展管理器
我们将更新的扩展管理器带给所有用户!在过去的一年里,我们已经将更新后的扩展管理器作为可选的预览功能提供,并一直期待您的反馈.基于您令人难以置信的反馈,我们现在准备从 Visual Studio 17. ...
- 聊聊GLM-4-9B开源模型的微调loss计算
概述 Github官方地址:GLM-4 网上已经有很多关于微调的文章,介绍各种方式下的使用,这里不会赘述.我个人比较关心的是微调时的loss计算逻辑,这点在很多的文章都不会有相关的描述,因为大多数人都 ...
- 彻底解决IDEA Jrebel 错误找不到口令文件的问题
本来我的Jrebel也是好用的,突然就变成了这个样子,网上针对这个问题有很多帖子,但是每次新建项目后我都需要去解决一下这个问题,这我不能忍,经过一整天的百度和测试终于找到了原因并解决这个问题,伸手党直 ...
- uniapp 使用z-paging 分页组件 写在头部插槽内的单选按钮无法点击
这个问题是因为组件层级太低 <z-paging ref="paging" v-model="dataList" @query="queryLis ...
- 使用GET方法访问网站
使用GET方法访问网站 服务器接收get参数 server.py import flask app = flask.Flask(__name__) @app.route('/') def index( ...