Symfony2: Entity recreated after renamed - php

I've created a bundle Super, and created relative Entity "sin_table1.php" as "sin_table1" mysql table generation.
After an:
php app/console doctrine:generate:entities AcmeSuperBundle
and
php app/console doctrine:schema:update --force
Now i can see the full mysql table generated.
But if i rename sin_table1.php to another name as "mysql_schema.php", and i try to reload that commands, doctrine/symfony2 recreate "sin_table1.php" Entity file.
I tried to grep "sin_table1" key into symfony2 root project, but nothing found. Only caches, logs and the two Entitiy files(sin_table1.php & mysql_schema.php).
I've tried to clean cache, but nothing happened, always sin_table1.php recreated, and conflicts with mysql_schema.php because there is a double decaration of the same class.
How i can resolve it? where doctrine have sin_table1 entity configuration saved? why this happen?
i think that i've lost something reading manual....

Namefile: mysql_schema.php
namespace Acme\SuperBundle\Entity;`
use Doctrine\ORM\Mapping as ORM;`
/**`
* #ORM\Entity`
* #ORM\Table(name="sin_table1")`
*/`
class sin_table1`
{....`
In my new test, i've renamed clas as "sin_tablerrrrrrrrrr" and also #ORM\Table(name="sin_tablerrrrrrrrrr"....
and the result will be another file sin_tablerrrrrrrrrr.php created
If my supposition that namefile must be the same of the class, i could be sign as solved.

I've always set my class name identical to my php file name. I guess it's more a developer convention / best practice that an obligation.
Anyway, I've got the same problem few weeks ago and I saw that the command php app/console doctrine:schema:drop doesn't delete a renamed table. The table with the old name was not deleted by the command. So when I updated I had the both tables. Maybe it was your problem.

Related

I cannot remove entity class from symfony project without mistakes

I have the project with symfony5 and doctrine orm. I created entity in my project. And now I want to delete the entity from model. I deleted relashionships this entity and made migration. Then i deleted this entities from the project and made migration. But when I try to create new entity in php bin/console, i get next error:
Warning: include(C:\OpenServer\elearning\vendor\composer/../../src/Entity/Theme.php): failed to open stream: No such file or directory
What am i doing wrong?
I tried to make php bin/console d:s:u --force, but the error still appears
A little bit late but i just had the same problem.
Try running composer dump-autoload to generate a new classmap. Your ...\Entity\Theme.php probably still exists there.
After that, you should be able to run console commands again.

Symfony 4 correct way to configure "AppBundle" for entity Mapping

I am following this documentation since I want to auto generate entity depending on the table in my database, and at the XML generation stage I am passing this line php bin/console doctrine:mapping:import --force DoctrineMappingBundle xml. Since I dont have AppBundle, I created my own DoctrineMappingBundle.php in src/Entity/
My DoctrineMappingBundle.php looks like this
namespace App\Entity;
use Symfony\Component\HttpKernel\Bundle\Bundle;
class DoctrineMappingBundle extends Bundle
{
}
It does generate the XML files, however when I run the entity generation command
php bin/console doctrine:mapping:convert annotation ./src, it throws up this error
In MappingException.php line 317:
An error occurred in App\Entity\Entity\BlogComment
and
In AnnotationDriver.php line 60:
Class App\Entity\Entity\BlogComment does not exist
I am stuck at this point and I dont know why it could not generate the entity classes, and it seems to automatically add an extra Entity in the namespace but in my namespace Entity is only mentioned once in the namespace. I am not sure which configuration is causing this issue.
My src folder structure
src---------/
|--Controller/
|--Entity--/
|-----DoctinemappingBundle.php
|--Migrations/
|--Repository/
|--Kernel.php
First off, the docs make it clear that this functionality is no longer supported and if your read the github issue you will see why.
However the functionality is still there and your idea of using a fake bundle will work. Just need the mapping bundle to be in the src directory. And then a bit of copy/paste.
Here is a complete step by step approach to generating entities under S4.
// Install the software
mkdir mapping
cd mapping
composer create-project symfony/skeleton .
composer require orm-pack
// adjust DATABASE_URL in .env
Make a fake bundle for the mapping command:
// src/DoctrineMappingBundle.php
namespace App;
use Symfony\Component\HttpKernel\Bundle\Bundle;
class DoctrineMappingBundle extends Bundle
{
}
// Add the bundle to config/bundles.php
App\DoctrineMappingBundle::class => ['dev' => true],
Now we are ready to make some entities:
// Generate the xml mappings
bin/console doctrine:mapping:import DoctrineMappingBundle xml
// Mapping files generated under src/Resources/config/doctrine
// Generate the entities
php bin/console doctrine:mapping:convert annotation ./src
This generates the entities under src/App/Entity. At this point you will want to copy the generated entities to src/Entity and then remove the App/Entity directory. The namespace should already be correct.
Get rid of the mapping files by removing src/Resources as well.
This is as far as I took the exercise but you should be good to go.

Doctrine Exception - The table with name ['table_name'] already exists

I've created a single Entity with it's properties, getters and setters then I ran:
$ php bin/console doctrine:schema:update --force
Everything worked and the table was created in the database. Now I have a couple of new Entities that I also want to migrate. But when I run:
$ php bin/console doctrine:schema:validate
or
$ php bin/console doctrine:migrations:diff
I get this:
[Mapping] OK - The mapping files are correct.
[Doctrine\DBAL\Schema\SchemaException]
The table with name ['table_name'] already exists.
Of course the table already exists. I just created it. But I don't wanna remove the existing table's Entity. I also don't want Doctrine to ignore it because I created new associations. So what's wrong? How can I make Doctrine recognize existing tables and try to identify changes in it, instead of stopping the process when it finds it.

Can we Alter a table (entity) in Symfony 2.7.3 ? using CMD or manually?

Can we Alter a table Using Command Prompt in Symfony 2.7.3 ?
I have 3 Fields in an entity i.e. Product.
Now i want to add new field in existing Entity, also i want to modify field type of declared field.
I have used
php app/console schema:update --force
I have tried manual changing in Entity product.php, after manually changing entity file still not working. Kindly guide me accordingly. Thanks
While you are generating entity, symfony ask you to choose
configuration format for mapping information:
here you should choose annotation format type,
i was choosing yml format and after generating entities i could not update my schema with:
doctrine:schema:update --force
it was always showing me nothing to update your database is already sync with current entity metadata
then i generated a new entity and set configuration format type = annotation and after that now i can modify my entity with php (Product.php) and with doctrine:schema:update --force its working fine and my DB Table is ALTERING perfect.
Altering the entity via the command line is not possible but creating a new one is with php app/console doctrine:generate:entity - but that doesn't help you. You may only alter the entity manually (that is, by editing the entity.php file).
After changing the file you must run php app/console doctrine:schema:update --force for the change to affect your database. Notice that this command is slightly different than the command you tried to run. Be aware, using this command should not be used on your production server.

zf2 generating entity with doctrine ORM

I have Entity classes generated with Doctrine ORM, and ZF2.
I changed a table structure and I want to update an entity class, so I am trying to regenerate the entity class but it's not working.
I used the following code:
vendor/doctrine/doctrine-module/bin/doctrine-module orm:convert-mapping --namespace="Album\Entity\" --force --from-database annotation ./module/Album/src/clear
I got the error:
[Doctrine\ORM\Mapping\MappingException]
Property "status" in "Album\Entity\TestRun" was already declared, but it must be declared only once
orm:convert-mapping [--filter="..."] [--force] [--from-database] [--extend[="..."]] [--num-spaces[="..."]] [--namespace[="..."]] to-type dest-path
I want to re-generate the entity class for a particular table
If you change the structure of your Entity file a simple
\vendor\bin\doctrine-module orm:schema-tool:update --force will alter the table according to your Entity definition.
If you still want to recreate the table simple drop the table from your mysql and run the update command. You may have some cache files left so clearing those might be a good Idea, too.
You can clear the complete cache like so:
\vendor\bin\doctrine-module orm:clear-cache:query
\vendor\bin\doctrine-module orm:clear-cache:result
\vendor\bin\doctrine-module orm:clear-cache:metadata
As mentioned above it might be a bad practice, but nevertheless I use the following commands to achieve the result you are asking about:
vendor\bin\doctrine-module orm:convert-mapping --filter='Evaluation' --namespace='MyModule\Entity\\' --force --from-database annotation ./module/MyModule/src/
and another command to generate getters and setters:
vendor\bin\doctrine-module orm:generate-entities --filter='Evaluation' ./module/MyModule/src/ --generate-annotations=true

Categories