Heim  >  Fragen und Antworten  >  Hauptteil

symfony3 – Fragen Sie den Master: So ignorieren Sie das Tabellenpräfix, wenn Symfony Entitäten aus der Datenbank generiert

Fragen Sie den Meister: Wie ignoriere ich das Tabellenpräfix beim Generieren von Entitäten aus der Datenbank?

Zum Beispiel generiert t_test beim Generieren einer Entität direkt Test.

Gibt es eine Möglichkeit, dieses Problem zu lösen?

"php bin/console doctrine:mapping:import --force AdminBundle annotation"

PHPzPHPz2730 Tage vor699

Antworte allen(1)Ich werde antworten

  • 習慣沉默

    習慣沉默2017-05-16 16:45:49

    在配置项中我还没有找到表前缀的配置。在默认情况下 t_test 只能生成 entity Test.

    可以参考 配置前缀处理 或者这个 SQL-Table Prefixes ,追加了表前缀服务处理。

    简单的说是:
    修改 app/config/services.yml

    然后追加文件 src/AppBundle/Subscriber/TablePrefixSubscriber.php ,其中 AppBundle修改为自己的路径。
    文件内容为

    <?php
    namespace AppBundle\Subscriber;
    
    use Doctrine\ORM\Event\LoadClassMetadataEventArgs;
    use Doctrine\Common\EventSubscriber;
    
    class TablePrefixSubscriber implements EventSubscriber
    {
        protected $prefix = '';
    
        public function __construct($prefix)
        {
            $this->prefix = (string) $prefix;
        }
    
        public function getSubscribedEvents()
        {
            return array('loadClassMetadata');
        }
    
        public function loadClassMetadata(LoadClassMetadataEventArgs $eventArgs)
        {
            $classMetadata = $eventArgs->getClassMetadata();
    
            if (!$classMetadata->isInheritanceTypeSingleTable() || $classMetadata->getName() === $classMetadata->rootEntityName) {
                $classMetadata->setTableName($this->prefix . $classMetadata->getTableName());
            }
    
            foreach ($classMetadata->getAssociationMappings() as $fieldName => $mapping) {
                if ($mapping['type'] == \Doctrine\ORM\Mapping\ClassMetadataInfo::MANY_TO_MANY && $mapping['isOwningSide']) {
                    $mappedTableName = $mapping['joinTable']['name'];
                    $classMetadata->associationMappings[$fieldName]['joinTable']['name'] = $this->prefix . $mappedTableName;
                }
            }
        }
    }

    Antwort
    0
  • StornierenAntwort