mybatis学习笔记--常见的问题
来源:互联网 发布:淘宝上的学历是真的吗 编辑:程序博客网 时间:2024/06/12 15:26
1. #{...} 和 ${...} 有什么区别?
mybati 将#{...} 解释为jdbc prepared statement 中的参数, 而将$ {...}用作字符串的替换功能.知道其中的差别重要的是很重要,因为在某些地方,在SQL语句的某些地方不能使用参数创造器. 例如,您不能使用一个参数标记指定表名. 例如下面的代码:- Map<String, Object> parms = new HashMap<String, Object>();
- parms.put("table", "foo");
- parms.put("criteria", 37);
- List<Object> rows = mapper.generalSelect(parms);
- <select id="generalSelect" parameterType="map">
- select * from ${table} where col1 = #{criteria}
- </select>
mybatis会生成如下的prepared statement
- select * from foo where col1 = ?
小提示: 使用${}(字符串替换)会有注入攻击的危险, 并且在多种类型(如时间类型)并存的情况下会产生较多的问题, 所以建议使用#{}, 而非${}.
2.如何编写模糊查询语句(like 语句)?
两种方法:
1,在java代码中用SQL通配符追加(推荐首选),如下例:
- String wildcardName = "%Smi%";
- List<Name> names = mapper.selectLike(wildcardName);
- <select id="selectLike">
- select * from foo where bar like #{value}
- </select>
- String wildcardName = "Smi";
- List<Name> names = mapper.selectLike(wildcardName);
- <select id="selectLike">
- select * from foo where bar like '%' || '${value}' || '%'
- </select>
3. 我怎么编写一个批处理insert呢?
首先,写一个插入的声明语句,如下:- <insert id="insertName">
- insert into names (name) values (#{value})
- </insert>
- List<String> names = new ArrayList<String>();
- names.add("Fred");
- names.add("Barney");
- names.add("Betty");
- names.add("Wilma");
- SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
- try {
- NameMapper mapper = sqlSession.getMapper(NameMapper.class);
- for (String name : names) {
- mapper.insertName(name);
- }
- sqlSession.commit();
- } finally {
- sqlSession.close();
- }
4.怎么查询自增长的key值呢?(即怎么查刚刚插入的那条数据的id).
insert方法总是返回一个int类型的数字,这个数字就是刚刚插入数据的行号,也就是id. 自增长的key值先放入参数对象中,待插入操作完成后可见.如下例子:- <insert id="insertName" useGeneratedKeys="true" keyProperty="id">
- insert into names (name) values (#{name})
- </insert>
- Name name = new Name();
- name.setName("Fred");
- int rows = mapper.insertName(name);
- System.out.println("rows inserted = " + rows);
- System.out.println("generated key value = " + name.getId());
5. 怎么在一个映射中使用多个参数?
java的反射并不知能知道方法的各参数名,mabatis中默认将他们命名为:param1,param2....如果你想重命名的话,使用@param 声明的方式.如下:- import org.apache.ibatis.annotations.Param;
- public interface UserMapper {
- User selectUser(@Param("username") String username, @Param("hashedPassword") String hashedPassword);
- }
- <select id=”selectUser” resultType=”User”>
- select id, username, hashedPassword
- from some_table
- where username = #{username}
- and hashedPassword = #{hashedPassword}
- </select>
the end !
转载自 :鼠口拔牙博客 http://blog.csdn.net/nich002/article/details/8930059
1 0
- mybatis学习笔记--常见的问题
- mybatis学习笔记--常见的问题
- mybatis学习笔记--常见的错误
- mybatis学习笔记--常见的错误
- MyBatis的学习笔记
- mybatis学习的笔记
- Mybatis学习笔记-关联表查询的问题
- 【菜鸟C++学习笔记】24. 常见的引用注意问题
- MyBatis学习笔记-MyBatis包含的jdbcType
- Mybatis学习笔记-MyBatis缓存的使用
- c++学习笔记三-常见基础问题
- Mybatis(问题一)开发过程中常见的问题
- Mybatis Generator 自动生成代码和常见的问题
- springmvc学习笔记(21)-springmvc整合mybatis遇到的问题及解决小结
- springmvc学习笔记(21)-springmvc整合mybatis遇到的问题及解决小结
- Mybatis学习笔记-关联表查询的问题 (一对多关联)
- Mybatis学习笔记-mybatis对时间的处理
- Mybatis学习笔记-Mybatis与Spring的整合
- FIQ和IRQ区别
- Lua package
- 【索引】Volume 0. Getting Started
- C#泛型与委托:一个简单的数组模板示例
- PHP工作模型与运行机制
- mybatis学习笔记--常见的问题
- scanf含有非输入控制符
- 数组深入学习
- Python批量裁切影像
- linux 忘记root密码的补救
- Java HashMap 分析之一:基本结构
- log4net的各种输出配置
- 子集生成
- simcom工作记录