0

接下来大家,我正在尝试查询(UPDATE)以借记由script_id + cnpj标识的公司的XX(值)中的贷方。即,价值也将动态地识别公司。当我运行时出现以下错误: [Err] 1093 - You can not specify target table 'company' for update in FROM 子句已经用谷歌搜索,尝试优化代码,但没有看到执行此查询的另一种方法。

UPDATE empresa  
SET saldo = saldo - ( 
        SELECT
        preco
    FROM
        preco_servico
    WHERE
        id = (
            SELECT
                emp2.idEscritorio
            FROM
                empresa AS emp2
            WHERE
                razao_social = (
                    SELECT
                        emp3.associacao
                    FROM
                        empresa AS emp3
                    WHERE
                        idEscritorio = (
                            SELECT
                                certidao_contratada.empresa_idEscritorio AS idEscritorio
                            FROM
                                certidao_contratada
                            INNER JOIN certidao_processada ON certidao_contratada.cnpj_idCnpj = certidao_processada.certidao_contratada_cnpj_idCnpj
                            WHERE
                                certidao_processada.certidao_contratada_scripts_idScript = 68 #script_id
                            AND certidao_processada.certidao_contratada_cnpj_idCnpj = '34.997.015/0001-98' #cnpj (da certidão)
                            ORDER BY
                                certidao_processada.dataHoraConcluido DESC
                            LIMIT 1
                        )
                )
        )
    AND tipo_servico LIKE 'b%'
)
WHERE
    emp1.idEscritorio = (
        SELECT
            certidao_contratada.empresa_idEscritorio AS idEscritorio
        FROM
            certidao_contratada
        INNER JOIN certidao_processada ON certidao_contratada.cnpj_idCnpj = certidao_processada.certidao_contratada_cnpj_idCnpj
        WHERE
            certidao_processada.certidao_contratada_scripts_idScript = 68 #script_id
        AND certidao_processada.certidao_contratada_cnpj_idCnpj = '34.997.015/0001-98' #cnpj (da certidão)
        ORDER BY
            certidao_processada.dataHoraConcluido DESC
        LIMIT 1
    );`
4

0 回答 0