請教大神: 從資料庫產生 entity 怎麼忽略 表前綴?
例如 t_test 產生entity的時候直接產生 Test。
有什麼方法可以解決這個問題嗎, 跪謝 !
「php bin/console doctrine:mapping:import --force AdminBundle annotation 」
学习是最好的投资!
在配置項目中我還沒有找到表前綴的配置。在預設情況下 t_test 只能生成 entity Test.
t_test
entity
Test
可以參考 設定前綴處理 或這個 SQL-Table Prefixes ,追加了表格前綴服務處理。
簡單的說是:修改 app/config/services.yml
app/config/services.yml
然後追加檔案 src/AppBundle/Subscriber/TablePrefixSubscriber.php ,其中 AppBundle修改為自己的路徑。 文件內容為
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; } } } }
在配置項目中我還沒有找到表前綴的配置。在預設情況下
t_test
只能生成entity
Test
.可以參考 設定前綴處理 或這個 SQL-Table Prefixes ,追加了表格前綴服務處理。
簡單的說是:
修改
app/config/services.yml
然後追加檔案
src/AppBundle/Subscriber/TablePrefixSubscriber.php
,其中AppBundle
修改為自己的路徑。文件內容為