我有一个使用 Spring 的名为 JDBC 的 mysql batchUpdate,如下所示:
public SqlParameterSource[] getBatchParamsArray(Collection params) {
List<SqlParameterSource> dbParams = new ArrayList<>();
for(Object p: params) {
BeanPropertySqlParameterSource beanPropertySqlParameterSource = new BeanPropertySqlParameterSource(p);
dbParams.add(beanPropertySqlParameterSource);
}
return dbParams.toArray(new SqlParameterSource[0]);
}
其用法如下:
String SQL = "INSERT INTO mytable (user_id, related_user_id,:tagName) VALUES (:userId,:relatedUserId,:taggedAt) ON DUPLICATE KEY UPDATE set :tagName=:taggedAt"
this.namedJDBC.batchUpdate(SQL, this.getBatchParamsArray(listOfPOJOs));
我的问题是batchUpdate转义了列名,导致查询如下:
INSERT INTO mytable (tuser_id, related_user_id,'some_tag') VALUES (1234,24542336,'2015-12-17 10:44:25') ON DUPLICATE KEY UPDATE 'some_tag'='2015-12-17 10:44:25'
列 some_tag 存在,但转义 ' 使 SQL 查询失败,那么如何防止转义并手动执行,或者以其他方式实现批量插入所需的通用功能
最佳答案
到目前为止,似乎不可能,我也尝试过:
SET @tagName='some_tag'; INSERT INTO myTable (user_id, related_user_id,@tagName) ....
还是同样的问题。 所以我的结果是:
this.getConnection().setAutoCommit(false);
for(POJO t:listOfPOJOs) {
this.namedJDBC.update(SQL.replace(":tagName",t.getTagName()), new BeanPropertySqlParameterSource(t));
}
this.getConnection().setAutoCommit(true);
因此,感谢您在这里提供反馈!
关于java - MySQL Java Spring batchUpdate 列名转义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34501843/