I\'m implementing repository pattern in company solution I work for, separating model classes in a Backend project and database context and migrations in DbContexts project.
It is now possible to redirect the generated context with -ContextDir option:
-ContextDir The directory to put DbContext file in. Paths are relative to the project directory.
So in your case it would be something like this:
Scaffold-DbContext "*connection*" "*provider*" -OutputDir "BackendProject" -ContextDir "DbContexts"
Source: https://docs.microsoft.com/en-us/ef/core/miscellaneous/cli/powershell
Yes, you can do that with my "EF Core Power Tools" free Visual Studio extension:
https://github.com/ErikEJ/SqlCeToolbox/wiki/EF-Core-Power-Tools
You need to change the Default Project to the project which you want to generate entities in, also specify the folder (using OutputDir switch) where you want to generate the model definition. Example is below
Scaffold-DbContext "Data Source=.\SQLEXPRESS;Initial Catalog=DbName;Integrated Security=SSPI;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -f -d
I faced a similar problem. I had my EF models in a separate project. In order to write the models there, I just used the following command:
Scaffold-DbContext "Server=[Server];Database=[Database Name];Trsted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -Project "[Project Name]" -Force
The key for me was the -Project "[Project Name]" -Force
option.
As the top answer indicates, if you want a different folder within that project, you can just use the -OutputDir
option.
Short answer: no.
Currently, the output folder will contain the models and the context, and it's not possible to change their namespace either.
You can look here for the supported parameters.