Workaround for MySQL’s “can’t specify target table for update in FROM clause” Error

0
882

jOOQ workaround for "can't specify target table for update in FROM clause"

In MySQL, you cannot do this:

create table t (i int primary key, j int);
insert into t values (1, 1);

update t
set j = (select max(j) from t) + 1;

The UPDATE statement will raise an error as follows:

SQL Error [1093] [HY000]: You can’t specify target table ‘t’ for update in FROM clause

People have considered this to be a bug in MySQL for ages, as most other RDBMS can do this without any issues, including MySQL clones:

  • MariaDB 10.2
  • SingleStore 6 (previously known as MemSQL)

Luckily, jOOQ can easily transform such queries for you, whenever you’re trying to UPDATE or DELETE a target table, with a predicate that depends on the target table itself. In those cases, jOOQ will just apply the following workaround:

update t
set j = (
  select *
  from (
    select max(j) from t
  ) t
) + 1;

Now, the query works without any syntactic issues. Similar workarounds are documented in the MySQL docs, but with jOOQ, you simply don’t have to think about this limitation.

Published by lukaseder

I made jOOQ

Sponzorováno
Sponzorováno
Sponzorováno
Sponzorováno
Sponzorováno
Hledat
Sponzorováno
Virtuala FansOnly
CDN FREE
Cloud Convert
Kategorie
Číst více
Ostatní
Car Care Products Market Size and Regional Insights
Market OverviewAccording To The Research Report Published By Polaris Market Research, The Global...
Od MAYUR YADAV 2025-09-25 10:45:02 0 554
Art
DJI Mic 3 Review: Das beste drahtlose Mikrofon wird noch besser
DJI, Mikrofone, drahtlos, Audiotechnik, Review, DJI Mic 3, Technik, Gadget, Soundqualität ##...
Od Sophie Leni 2025-08-29 09:05:23 1 514
Art
Bericht: Die Skepsis der King-Führung gegenüber Microsofts KI-Mandat
KI, Microsoft, King, Skepsis, ChatGPT, KI-Adoption, Technologie, Führung, digitale...
Od Hannah Elisa 2025-08-28 01:05:20 1 987
Sponzorováno
Virtuala FansOnly https://virtuala.site