0

次に、スクリプト ID + cnpj で識別される会社の XX (値) のクレジットを引き落とすクエリ (UPDATE) を作成しようとしています。つまり、値は動的に会社を識別します。実行すると次のエラーが表示されます: [Err] 1093 - FROM 句で更新するターゲット テーブル 'company' を指定できません

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