sql >> Database >  >> RDS >> Mysql

Fout (1093):U kunt de doeltabel niet bijwerken voor update in de FROM-clausule

wikkel het in een subquery (waardoor een tijdelijke tabel wordt gemaakt )

UPDATE  o_daily_lcsgeneration_copy
SET     o_daily_lcsgeneration_copy.Billing_cycle = 
(
    SELECT Billing_cycle
    FROM
    (
        SELECT  s_billing_cycle.Billing_cycle
        FROM    s_billing_cycle
                INNER JOIN o_daily_lcsgeneration_copy
                    ON o_daily_lcsgeneration_copy.Location = s_billing_cycle.Location
        WHERE   o_daily_lcsgeneration_copy.DATE BETWEEN s_billing_cycle.From_Date
                AND s_billing_cycle.To_Date
    ) s
)

of JOIN de tafels

UPDATE  o_daily_lcsgeneration_copy a
        INNER JOIN s_billing_cycle b
            ON a.Location = b.Location
SET     a.Billing_cycle = b.Billing_cycle
WHERE   a.DATE BETWEEN b.From_Date AND b.To_Date



  1. MySQL - Hoe toon ik alle dagenrecords in een bepaalde maand?

  2. Hoe cx_oracle te bundelen met Pyinstaller

  3. Oracle 12c Installation heeft geen toegang tot de tijdelijke locatie

  4. 6 manieren om dubbele rijen in SQLite te selecteren