Java+;MySQL+;内联用户变量:相同的查询在SQL编辑器中工作,JDBD(org.skife.jdbi)中的结果错误
我正在运行这样的查询:Java+;MySQL+;内联用户变量:相同的查询在SQL编辑器中工作,JDBD(org.skife.jdbi)中的结果错误,java,mysql,jdbc,jdbi,Java,Mysql,Jdbc,Jdbi,我正在运行这样的查询: INSERT INTO `ABC` ( `col1`, `col2`) SELECT `t`.`col1`, `t`.`col2` FROM ( SELECT `opr`.`col1`, @counter := IF(@var_2 = `opr`.`col_2`, @counter + 1, 1) AS `counter`, @val_2 := `opr`.`col2` FROM (...Some select ...) `opr` )
INSERT INTO `ABC` (
`col1`,
`col2`)
SELECT
`t`.`col1`,
`t`.`col2`
FROM (
SELECT
`opr`.`col1`,
@counter := IF(@var_2 = `opr`.`col_2`, @counter + 1, 1) AS `counter`,
@val_2 := `opr`.`col2`
FROM
(...Some select ...) `opr`
) t
在SequelPro(SQL编辑器)中运行此查询非常理想。
但是,当使用org.skife.jdbi(作为@SqlUpdate)运行此命令时,用户定义的变量@counter始终为1,从而生成错误的更新
此外,我还尝试将此更新查询扭曲到存储过程中:
-当我从SequelPro调用SP时,我得到了正确的结果。
-当我从JDBI调用SP时,我得到了错误的结果(@counter==1)
Java正在执行的SQL查询是正确的(我查看了MySQL日志以检查Java正在执行的内容),但是,无论是调用显式查询还是调用包含查询的SP,都无法正确计算用户定义的变量
想法?这是JDBC或org.skife.jdbi的错误吗?找到了解决方案:
如果JDBC启动了一个新的/空白的客户机环境,那么变量只存在于查询环境(或类似环境)的上下文中
- 由于变量以前从未设置过,因此它们最初未定义
- 另一方面,SQL编辑器将持久化它们
(SELECT @var_1 := 0, @var_2 := 0) initialize_variables,
在操作之前,选择嵌套
这是我最后一个查询的结构,它解决了这个问题:
INSERT INTO `table_name` (
`col_1`, `col_2`)
SELECT
`query `.`col_1 `,
`query `.`col_2`
FROM
(SELECT @var_1 := 0, @counter := 0) `initialize_variables`,
(
SELECT
...values...,
@counter := IF(@var_1 = `col_1`, @counter + 1, 1) AS `col_1`,
@var_1 := `col_2`
FROM
... some fancy query ...
) `query`
如果将它与普通JDBC一起使用,您能获得预期的结果吗?