Mybatis基础: 常见问题与FAQ
来源:互联网 发布:电子电路软件哪个好 编辑:程序博客网 时间:2024/05/29 16:12
Mybatis基础: #{...} 和 ${...} 的区别
MyBatis将 #{…} 解释为JDBC prepared statement 的一个参数标记。而将 ${…} 解释为字符串替换。理解这两者的区别是很有用的, 因为在某些SQL语句中并不能使用参数标记(parameter markers)。比如,我们不能在表名(table name)的位置使用参数标记。
假设有下面的代码:
MyBatis生成的SQL语句(prepared statement)如下所示:
重要提示: 请注意,使用$ {…} (字符串替换)时可能会有SQL注入攻击的风险。另外,字符串替换在处理复杂类型也可能常常发生问题,如日期类型。由于这些因素,我们建议您尽可能地使用 #{…} 这种方式。
要使用LIKE语句该怎么写?
有两种使用LIKE的方法。(推荐使用)第一种方法是,在Java代码中添加SQL通配符。
示例一:第二种方式是在SQL语句中拼接通配符。这种方法相对来说安全性要低一些,因为可能会被SQL注入攻击。
示例二:
重要提示: 请注意两种方式中 $ 和 # 的使用!
如何执行批量插入?
首先,创建一个简单的insert语句:
然后在Java代码中像下面这样执行批处理插入:
如何获取自动生成的(主)键值?
insert 方法总是返回一个int值 - 这个值代表的是插入的行数。而自动生成的键值在 insert 方法执行完后可以被设置到传入的参数对象中。
示例:
在mapper中如何传递多个参数?
Java的反射机制并不能让框架获取到参数的名字(方法签名中只有参数类型,可以说是为了优化,也可以说设计就是如此,总之名字无意义), 所以MyBatis默认的命名为: param1,param2……如果想给他们指定名称,可以使用 @param 注解:
然后,就可以在xml像下面这样使用(推荐封装为一个Map,作为单个参数传递给Mapper):
原文链接: http://blog.csdn.net/renfufei/article/details/39649707
阅读全文
0 0
- Mybatis基础: 常见问题与FAQ
- Mybatis基础: 常见问题与FAQ
- mybatis 常见问题 FAQ
- WPA与WML常见问题(FAQ)
- Mybatis FAQ
- ASP.NET Web Matrix FAQ(常见问题与解答)
- Python常见问题(1):来历与简介General Python FAQ
- minij2ee常见问题(FAQ)
- Solaris常见问题解答 (FAQ)
- linux常见问题FAQ
- MP3常见问题FAQ
- JBuilderX 常见问题FAQ
- DWF常见问题faq
- WAP常见问题FAQ
- WAP常见问题FAQ
- Linux常见问题(FAQ)
- 关于BCG常见问题 FAQ
- db2常见问题 FAQ
- 学习笔记48-操作系统
- numpy的axis的学习
- 【个人笔记】console.log输出
- leetcode 495. Teemo Attacking
- 软件调试笔记53
- Mybatis基础: 常见问题与FAQ
- Chrome开发者工具不完全指南(一、基础功能篇)
- PL/SQL Developer 注册使用图文教程
- 数字三角形问题[动态规划]
- Android Studio 一些使用经验
- LeetCode题解系列--714. Best Time to Buy and Sell Stock with Transaction Fee
- PHP入门——运算符
- 基础知识
- 二分查找法