Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql SpringJDBC模板条件插入_Sql_Spring_Spring Jdbc - Fatal编程技术网

Sql SpringJDBC模板条件插入

Sql SpringJDBC模板条件插入,sql,spring,spring-jdbc,Sql,Spring,Spring Jdbc,例如,我正在尝试基于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 )

例如,我正在尝试基于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);
List params=new ArrayList();
add(新对象[]{1,2,3});
getSimpleJdbcTemplate.batchUpdate(
插入到某个表中(可乐、可乐、可乐)+
“值(?,?)”+
“WHERE EXISTS(//某些条件)”,参数);
这显然不起作用,我发现的最接近的例子包括 从表中选择插入值,而不是列表参数,这正是我所需要的。如何引用对象[]参数作为插入值的一部分


谢谢。

我认为您应该在单独的SELECT中移动此条件。

作为示例,您应该尝试以下语法和SimpleJDCoperations.update方法:

getSimpleJdbcTemplate.update(
    " INSERT INTO SomeTable( colA, colB, colC)" +
    " SELECT srcA, srcB, srcC" +
    " FROM src_table" +
    " WHERE EXISTS ( // some condition )",
    params
);
此外,我一直在使用它来生成动态SQL。这是我用过的最好的语言

例如(作为StringTemplate语法):


你能举个例子吗?SELECT的问题是,我认为我必须引用表值,而我只想引用参数java变量。
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 generated