gpt4 book ai didi

java - MySQL Java Spring batchUpdate 列名转义

转载 作者:行者123 更新时间:2023-11-29 21:41:01 26 4
gpt4 key购买 nike

我有一个使用 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com