我正在尝试编写一个基于Java参数的条件批插入,例如
List<Object[]> params = new ArrayList();
params.add(new Object[]{1, 2, 3});
getSimpleJdbcTemplate.batchUpdate(
"INSERT INTO SomeTable( colA, colB, colC)" +
" VALUES(?, ?, ?)" +
" WHERE EXISTS ( // some condition )", params);这显然不起作用,我找到的最接近的例子是从表中选择插入值,而不是列表参数,这是我需要的。如何引用Object[]参数作为插入值的一部分?
谢谢。
发布于 2010-11-08 14:43:22
我要说的是,您应该在单独的SELECT中移动这个条件。
发布于 2010-11-08 15:27:15
作为示例,您应该尝试以下语法和SimpleJdbcOperations.update方法:
getSimpleJdbcTemplate.update(
" INSERT INTO SomeTable( colA, colB, colC)" +
" SELECT srcA, srcB, srcC" +
" FROM src_table" +
" WHERE EXISTS ( // some condition )",
params
);此外,我一直在使用StringTemplate生成动态SQL。这是我用过的最好的语言。
例如(作为StringTemplate语法):
StringTemplate tmpl = new StringTemplate(
" SELECT *" +
" FROM some_table" +
" WHERE 1 = 1" +
"$search_age:{ AND age = ?}$" +
"$search_name:{ AND name = ?}$"
);
/**
* if param_age is not null, "AND age = ?" would be included in argumented sql,
* same as param_name
*/
tmpl.setAttribute("age", param_age);
tmpl.setAttribute("name", param_name);
// :~)
String sqlTmpl = tmpl.toString(); // final SQL generatedhttps://stackoverflow.com/questions/4121091
复制相似问题