名称参数
在 SQL 语句使用 :name、&name 或 #{...} 写法,可以将 SQL 中的参数进行名称化。
select * from users where id > :id and name = :name
select * from users where id > &id and name = &name
select * from users where id > #{id} and name = #{name}
基本用法
例1:使用 Map 作为参数容器
Map<String, Object> args = CollectionUtils.asMap(
"id", 2,
"Dave", true
);
jdbcTemplate.queryForList("select * from users where id > :id and name = :name", args);
例2:使用 Bean 对象作为参数容器
public class User {
private int id;
private String name;
public User(int id, String name) {
this.id = id;
this.name = name;
}
// getters and setters omitted
}
User args = new User(2, "Dave");
jdbcTemplate.queryForList("select * from users where id > :id and name = :name", args);
OGNL 取值
三种命名参数写法(:name、&name、#{...})均支持 OGNL 表达式,可以进行嵌套属性访问、数组/集合索引、方法调用。
嵌套属性
例:提取嵌套结构中参数
{
"p": {
"name": "Dave",
"cfg_id": {
"array": [
{"age": 10},
{"age": 40} <<< 使用该属性作为参数
]
}
}
}
使用 OGNL 表达式 p.cfg_id.array[1].age 对上面结构的数据进行参数提取。
写法 1:冒号语法
select * from user_table where age > :p.cfg_id.array[1].age order by id
写法 2:花括号语法
select * from user_table where age > #{p.cfg_id.array[1].age} order by id
数组和集合索引
OGNL 表达式可以通过方括号 [index] 直接访问 List、数组中的元素。
例:集合索引取值
Map<String, Object> params = new HashMap<>();
params.put("ages", Arrays.asList(30, 35, 40));
params.put("names", new String[] { "Alice", "Bob" });
// 使用冒号语法
jdbcTemplate.queryForList(
"select * from users where age = :ages[0] and name = :names[0]", params);
// 使用花括号语法
jdbcTemplate.queryForList(
"select * from users where age = #{ages[0]} and name = #{names[0]}", params);
参数重用
同一个命名参数可以在 SQL 中出现多次,dbVisitor 会自动将其绑定到同一个值。
例:同一参数 name 使用两次
insert into users (id, name, email) values (#{id}, #{name}, #{name})
参数选项
例1:为参数指定 TypeHandler
select * from users where
id > #{id,typeHandler=net.hasor.dbvisitor.types.handler.number.LongTypeHandler}
and
name = #{name,typeHandler=net.hasor.dbvisitor.types.handler.string.StringTypeHandler}
例2:接收存储过程的 OUT 参数
{call proc_bigint(#{out,mode=out,jdbcType=bigint})}
拓展信息
- 使用
:name或&name写法不支持参数选项。 - 有关更多参数选项的信息请到 参数选项 查看。
忽略规则
在 SQL 中如果冒号 : 后面紧跟空白字符(如空格、换行、制表符等),dbVisitor 会忽略该冒号的参数解析,将其视为普通字符。
这一特性使得在 SQL 中可以直接书写 JSON 或类似 MongoDB 的查询语句,而无需对冒号进行转义。
-- 冒号后面有空格,不会被识别为参数
select * from table where config = '{ "key": "value" }'
此外需注意以下特殊处理:
- PostgreSQL 类型转换
::不会被识别为参数,可以安全使用column::integer语法。 - 引号内的内容 单引号
'...'和双引号"..."内的参数语法会被跳过。 - SQL 注释
/* ... */和-- ...内的参数语法会被跳过。 - 转义 使用
\#{...}、\${...}、\@{...}可以转义为普通文本。