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>
相关推荐
【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT必备】mybatis面试题【BAT...
mybatis面试题(经典问答) 1、JDBC有多少步? JDBC可以分为六个步骤 负载驱动程序 获取数据库连接 创建语句对象 操作数据库进行增删改查 获取结果集 关闭资源 2.什么是mybatis? 如果你在面试中被问到,只需说以下...
mybatis面试题.pdf
Mybatis面试题总结 本文总结了 Mybatis 面试中的一些常见问题,并对每个问题进行了详细的解释和分析。这些问题涵盖了 Mybatis 的基本原理、Mapper 接口、分页、插件运行原理、缓存机制等方面。 1. #{}和${}的区别 ...
### Mybatis面试题知识点解析 #### 1. #{}与${}的区别 - **#{}**:这是一种预编译处理方式。在Mybatis处理SQL时,#{}会被替换为SQL预编译语句中的问号(?),并在执行时通过`PreparedStatement`的`set`方法动态...
MyBatis面试题往往会围绕其核心特性、应用场景、优缺点以及与其他框架如Hibernate的对比进行展开。下面我们详细解释给出的一些面试知识点: 1. MyBatis的特性:MyBatis是一个半ORM(对象关系映射)框架,提供了对象...
MyBatis是一个流行的Java持久层框架,它允许开发者自定义SQL、存储过程和高级映射。这个框架的主要目的是简化数据库操作,将SQL语句与Java代码分离,提供更灵活的数据访问控制。 MyBatis的缓存机制是其性能优化的...
MyBatis是一款在中国乃至全球范围内广泛应用的...通过阅读《MyBatis面试题二(含答案)_.pdf》和《MyBatis面试题一.pdf》,你可以更全面地准备MyBatis相关的面试,理解并掌握这些知识点将有助于你在面试中脱颖而出。
MyBatis是一款优秀的持久层框架,它被归类为半ORM(对象关系映射)框架。相较于传统JDBC而言,MyBatis在处理数据库交互方面提供了更为便捷和高级的抽象。MyBatis的主要特点包括支持定制化SQL、存储过程、高级映射...
目录: 1. #{}和${}的区别是什么? 2. 通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应, 请问,这个 Dao 接口的工作原理是什么?...10. 简述 Mybatis 的 Xml 映射文件和 Mybatis 内部数据结构之间的映射关系
MyBatis 面试题整理详细版 MyBatis 是一个半 ORM(对象关系映射)框架,它内部封装了 JDBC,开发时只需要关注 SQL 语句本身,不需要花费精力去处理加载驱动、创建连接、创建 statement 等繁杂的过程。MyBatis 可以...
MyBatis面试题大全.rar
网罗各大MyBatis面试题做的整合,欢迎学习~ (1)Mybatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时只需要关注SQL语句本身,不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。...
mybatis面试题#和$的区别.pdf
MyBatis面试题.url
MyBatis面试题 MyBatis 是一个可以自定义 SQL、存储过程和高级映射的持久层框架。下面是 MyBatis 的一些常见知识点: 1. MyBatis 的缓存 MyBatis 的缓存分为一级缓存和二级缓存,一级缓存放在 session 里面,默认...
07-MyBatis面试题
【MyBatis面试题解析】 在Java开发领域,MyBatis作为一个轻量级的持久层框架,被广泛应用在各种项目中。它简化了数据库操作,提供了灵活的SQL映射机制,使得开发者能够更加自由地控制SQL执行。以下是一些关于...
### MyBatis 面试题及答案解析 #### 1. 什么是 MyBatis? - **定义**:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果...