搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
小桥流水78
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
iOS 系统提供的媒体资源选择器(PHPickerViewController)
2
循环神经网络六-Pytorch中的序列化器
3
跳表上线性dp——1150D 好题!
4
使用pytorch构建基于VGG16的网络实现Cifar10分类_基于pytorch实现vgg16模型进行cifar10数据集的分析预测
5
Set集合(Java) 及底层原理_set集合的底层原理
6
从入门到精通:Flutter完整开发指南
7
区间预测 | Matlab实现的集成学习长短期记忆神经网络自适应带宽核密度LSTM-Adaboost-ABKDE估计多变量回归区间预测_自适应核带宽
8
如何将idea的代码提交到git_idea怎么提交代码到git
9
mysql order by子查询_MySQL 子查询中的order by 不生效
10
庆祝法国队夺冠:用Python放一场烟花秀
当前位置:
article
> 正文
Mybatis常见面试题一
作者:小桥流水78 | 2024-08-04 01:15:12
赞
踩
Mybatis常见面试题一
1、Mybatis基础: #{...} 和 ${...} 的区别
MyBatis将 #{…} 解释为JDBC prepared statement 的一个参数标记。而将 ${…} 解释为字符串替换。理解这两者的区别是很有用的, 因为在某些SQL语句中并不能使用参数标记(parameter markers)。
比如,我们不能在表名(table name)的位置使用参数标记。
假设有下面的代码:
01.Map<String, Object> parms = new HashMap<String, Object>();
02.parms.put("table", "foo"); // 表名
03.parms.put("criteria", 37); // 查询过滤条件
04.List<Object> rows = mapper.generalSelect(parms);
01.<select id="generalSelect" parameterType="map">
02. select * from ${table} where col1 = #{criteria}
03.</select>
MyBatis生成的SQL语句(prepared statement)如下所示:
01.select * from foo where col1 = ?
重要提示: 请注意,使用$ {…} (字符串替换)时可能会有SQL注入攻击的风险。另外,字符串替换在处理复杂类型也可能常常发生问题,如日期类型。由于这些因素,我们建议您尽可能地使用 #{…} 这种方式。
要使用LIKE语句该怎么写?
2、有两种使用LIKE的方法。(推荐使用)第一种方法是,在
Java
代码中添加SQL通配符。
示例一:
01.String wildcardName = "%Smi%";
02.List<Name> names = mapper.selectLike(wildcardName);
01.<select id="selectLike">
02. select * from foo where bar like #{value}
03.</select>
第二种方式是在SQL语句中拼接通配符。这种方法相对来说安全性要低一些,因为可能会被SQL注入攻击。
示例二:
01.String wildcardName = "Smi";
02.List<Name> names = mapper.selectLike(wildcardName);
01.<select id="selectLike">
02. select * from foo where bar like '%' || '${value}' || '%'
03.</select>
重要提示: 请注意两种方式中 $ 和 # 的使用!
3、如何执行批量插入?
首先,创建一个简单的insert语句:
01.<insert id="insertName">
02. insert into names (name) values (#{value})
03.</insert>
然后在Java代码中像下面这样执行批处理插入:
01.List<String> names = new ArrayList<String>();
02.names.add("Fred");
03.names.add("Barney");
04.names.add("Betty");
05.names.add("Wilma");
06.
07.// 注意这里 ExecutorType.BATCH
08.SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
09.try {
10. NameMapper mapper = sqlSession.getMapper(NameMapper.class);
11. for (String name : names) {
12. mapper.insertName(name);
13. }
14. sqlSession.commit();
15.} finally {
16. sqlSession.close();
17.}
4、如何获取自动生成的(主)键值?
insert 方法总是返回一个int值 - 这个值代表的是插入的行数。而自动生成的键值在 insert 方法执行完后可以被设置到传入的参数对象中。
示例:
01.<insert id="insertName" useGeneratedKeys="true" keyProperty="id">
02. insert into names (name) values (#{name})
03.</insert>
01.Name name = new Name();
02.name.setName("Fred");
03.
04.int rows = mapper.insertName(name);
05.// 完成后,id已经被设置到对象中
06.System.out.println("rows inserted = " + rows);
07.System.out.println("generated key value = " + name.getId());
5、在mapper中如何传递多个参数?
Java的反射机制并不能让框架获取到参数的名字(方法签名中只有参数类型,可以说是为了优化,也可以说设计就是如此,总之名字无意义), 所以MyBatis默认的命名为: param1,param2……
如果想给他们指定名称,可以使用 @param 注解:
01.import org.apache.ibatis.annotations.Param;
02.public interface UserMapper {
03. User selectUser(@Param("username") String username,
04. @Param("hashedPassword") String hashedPassword);
05.}
然后,就可以在xml像下面这样使用(推荐封装为一个Map,作为单个参数传递给Mapper):
01.<select id=”selectUser” resultType=”User”>
02. select id, username, hashedPassword
03. from some_table
04. where username = #{username}
05. and hashedPassword = #{hashedPassword}
06.</select>
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/小桥流水78/article/detail/925661
推荐阅读
article
java
音乐网站
源码_Vue +
SpringBoot
+
MyBatis
音乐网站
...
一、前言这里对
音乐网站
这个项目的开发流程做一下描述,我觉得了解了具体实现的来龙去脉,上手自己做就容易得多了,要知道数据是...
赞
踩
article
一个界面现代美观,色彩年轻化的
Vue3
+
SpringBoot3
前后端分离中后台管理
脚手架
_sprin...
ContiNew Admin (Continue New Admin)中后台管理框架/
脚手架
,持续以最新流行技术栈构建,...
赞
踩
article
SSM
(
Spring
+
Spring
MVC
+
MyBatis
)
框架
面试三道题...
在这个过程中,DispatcherServlet起到了核心作用,它作为前端控制器,负责接收请求、分发请求、处理响应等。它...
赞
踩
article
SSM
整合-(
spring
+
spring
mvc
+
Mybatis
)_ssm+
mybatis
+spri...
二、系统架构图。_ssm+
mybatis
+
spring
+
spring
mvc
ssm+
mybatis
+
spring
+spri...
赞
踩
article
SSM
框架
:
spring
+
spring
MVC+
Mybatis
...
本文介绍了
SSM
框架
,包括Spring、SpringMVC和
Mybatis
的作用和关系。
SSM
是基于MVC模式的,将系统...
赞
踩
article
2024最新 SSM(
Spring
+
Spring
MVC+
MyBatis
)框架整合搭建详细步骤_sp...
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。深知大多数...
赞
踩
article
SSM
框架
——详细
整合
教程(
Spring
+
Spring
MVC+
MyBatis
)_
ssm
教程...
使用
SSM
(
Spring
、
Spring
MVC和Mybatis)已经有三个多月了,项目在技术上已经没有什么难点了,基于现有...
赞
踩
article
SpringMVC
框架+
spring
框架+
Mybatis
框架(
SSM
框架整合)_
spring
+spr...
1.1原始方法整合 1.准备工作 2.创建Maven项目 _
spring
+
spring
mvc+
mybatis
spri...
赞
踩
article
1.
Spring
Boot
简介(
Spring
MVC+Mybatis-
plus
)_springbo...
Spring
Boot
是
Spring
的子工程(或是spring的脚手架),快速搭建spring项目,自动配置了
Spring
...
赞
踩
article
基于
SpringBoot
+Mybatis+
Mysql
大学生
科创
项目
在线
管理系统
的设计与实现_基于my...
传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费...
赞
踩
article
Spring
boot
2
.x+Mybatis+
Shiro
+
Maven
+Mysql+
Redis
+Layu...
一款基于
Spring
boot
2
.x+Mybatis+
Shiro
+
Maven
+
Redis
+
LayuiAdmin
构建的JAV...
赞
踩
article
Mybatis
(四)特殊
SQL
的
查询
:
模糊
查询
、批量删除、动态设置表明、添加功能获取自增
的
主键_my...
不适用#{ },’%?%‘ 问号是属于字符串
的
一部分 不会被解析成占位符,会被当作是我们字符串
的
一部分来解析,所以我们执...
赞
踩
article
SSM
(
Spring
,
Spring
MVC
,
MyBatis
)开发
实战
_ssm
框架
实战
...
SSM
是当今Java项目开发行业使用官方的开发
框架
整合,其在
Spring
框架
的基础上进行了有效的功能扩充,使其可以轻松的...
赞
踩
article
SpringBoot
接口返回
数据
脱敏
(
Mybatis
、
Jackson
)_
springboot
电话脱...
J
数据
脱敏
有以下几种做法:1、通过自定义
Jackson
注解,实现在属性序列化过程中处理
数据
2、通过
Mybatis
查询
数据
...
赞
踩
article
Java
后端开发(
Maven
、
Mybatis
、
Mybatis
Plus
_
mybatisplus
ma...
jar 包的下载: 使用
Maven
之后,iar 包会从规范的远程仓库下载到本地。jar 包之间的冲突: 通过对依赖的...
赞
踩
article
mybatis
注解
开发笔记_
mybatis
注解
开发笔记...
mybatis
注解
开发笔记_
mybatis
注解
开发笔记
mybatis
注解
开发笔记 ...
赞
踩
article
MyBatis
-学习笔记
12
【
12
.
Mybatis
注解
开发】_
mybatis
注解
关系 保存...
MyBatis
-学习笔记
12
【
12
.
Mybatis
注解
开发】_
mybatis
注解
关系 保存
mybatis
注解
关系...
赞
踩
article
MyBatis
注解
开发 学习笔记...
通常情况下,都使用xml文件保存SQL语句,每一个mapper接口,就有一个对应的mapper的xml文件。在比较简单的...
赞
踩
article
Mybatis
-----
实验
小结_
mybatis
实验
总结...
1 第一个入门case的小结① XXXMapper.xml文件中,namespace必须是接口全路径② XXXMappe...
赞
踩
article
springboot
+
springsecurity
+
mybatis
+
mysql
实现用户登...
springsecurity
主要的功能是 验证 和 授权。
springsecurity
主要的工作原理是:当我们在登录页...
赞
踩
相关标签
java音乐网站源码
mybatis generator生成example
vue mxgraph渲染xml页面
vue调用后端接口
音乐网java项目
音乐网站mysql表怎么弄
后端
前端
开发工具
java
spring
mvc
mybatis
ssm
springmvc
整合教程
ssm整合