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编辑器将持久化它们
在查询执行期间,:=setter在使用行值时首次未能初始化变量,不确定原因

但是,如果嵌套选择之前有另一个初始化变量的嵌套选择,则第二个选择(使用带有行值的:=setter的选择)的行为是预期的行为

所以加上

(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一起使用,您能获得预期的结果吗?