Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BUG]This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery' #6096

Closed
EthanZqh opened this issue Nov 4, 2024 · 6 comments
Labels
bug Something isn't working

Comments

@EthanZqh
Copy link

EthanZqh commented Nov 4, 2024

The MySQL server version is community-based mysql-8.0.30-winx64 or community-based mysql-9.0.1-winx64
Limit&IN/ALL/ANY/OME subqueries are not yet supported
Solution problem: 1. Which MySQL version supports the "Limit&IN/ALL/ANY/OME subquery" query?
2. It is to modify the nested source code query, but I cannot modify the Elsa source code. I am referencing the Elsa Dll dynamic library.

elsa-mysql-err

@EthanZqh EthanZqh added the bug Something isn't working label Nov 4, 2024
@sfmskywalker
Copy link
Member

I tried with Docker container mysql:9.1.0, which works well.
If you need to support an older version of MySql, you can always generate your own EF Core migration files. Basically, copy the Elsa.EntityFrameworkCore.MySql project, rename the project and its classes and methods to be your own, and update the MySqlDesignTimeDbContextFactory class to use the version of MySQL that you want to use.

@sfmskywalker
Copy link
Member

I just noticed you had already posted this exact same issue here: #6091
I will close that one, since this issue now contains some feedback.

Please refrain from posting the same issues multiple times. Thank you.

@EthanZqh
Copy link
Author

I tried with Docker container mysql:9.1.0, which works well. If you need to support an older version of MySql, you can always generate your own EF Core migration files. Basically, copy the Elsa.EntityFrameworkCore.MySql project, rename the project and its classes and methods to be your own, and update the MySqlDesignTimeDbContextFactory class to use the version of MySQL that you want to use.

Upgrading MySQL to the community version MySQL-9.0.1-winx64 does not solve the problem and supports' Limit&IN/ALL/ANY/OME subqueries'. It may be necessary to change the source code nesting to solve the problem,
The code is as follows: DELETE w
FROM WorkflowInboxMessages AS w
WHERE w.Id IN (
SELECT w0.Id
FROM (select w1.Id from WorkflowInboxMessages AS w1
WHERE w1.ExpiresAt <= @__now_0
LIMIT 3 OFFSET 2) AS w0
)
I am unable to modify the source code. I hope the teacher can modify the source code to solve this problem. Thank you!

@sfmskywalker
Copy link
Member

Hi @EthanZqh , you don't need to change the source code. Instead, you can add your own class library project that contains the necessary migrations.

@EthanZqh
Copy link
Author

Hi @EthanZqh , you don't need to change the source code. Instead, you can add your own class library project that contains the necessary migrations.

I copied Elsa Entity Framework Core. MySQL project, and update MySqlDesignTimeVNet Factory class to use the MySQL version I want to use. How to generate EF Core migration files?
migrations

@sfmskywalker
Copy link
Member

See #6126

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants