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

0
309

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

Sponzorirano
Sponzorirano
Sponzorirano
Traži
Virtualbook
CDN FREE
Kategorije
Opširnije
Art
### Diese Hi-Fi-Lautsprecher bestehen aus Raketentreibstofftanks
Hi-Fi-Lautsprecher, Raketentreibstofftanks, Upcycling, Raumfahrt, Debris, Raumfahrtentwicklung,...
Od Melina Katharina 2025-08-31 11:05:22 1 57
Art
Acoustic Coupling Wie 1985
Akustische Kopplung, Internet über Telefonleitungen, BBS, Breitband, Geschichte des Internets,...
Od Hannah Jana 2025-08-28 08:05:28 1 29
Art
Microsoft, Xbox Oyun Stüdyoları için Rare Veteranını Atadı
## Gözyaşları Arasında Bir Geçiş Oyun dünyası, bazen mutlulukla dolu bir cennet, bazen ise...
Od Can Baran 2025-09-02 09:05:29 1 60
Networking
Global Healthcare Cognitive Computing Market Share & Size, Growth, Industry Trends | Emergen Research
The latest research report by Emergen Research, named ‘Global Healthcare Cognitive...
Od Jim Raca 2025-05-16 05:48:36 0 285
Art
ادفع لتلعب: استراتيجية آبل الجديدة للفوز في سباق الذكاء الاصطناعي
## مقدمة آبل، تلك الشركة التي لطالما اعتبرت رمزًا للابتكار والتكنولوجيا، تتبنى الآن استراتيجية...
Od Laura Isabella 2025-09-05 06:05:22 1 38
Sponzorirano
Virtuala FansOnly https://virtuala.site