是否可以有一个命名策略来处理 Doctrine ORM 中的映射表和列名?
现在所有名称都是通过实体类中的注释指定的,例如
<?php
namespace App\Entity;
use DateTimeInterface;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Entity()
* @ORM\Table(name="role")
*/
class Role
{
/**
* @ORM\Id()
* @ORM\Column(name="id", type="guid")
* @ORM\GeneratedValue(strategy="NONE")
* @var string
*/
private $id;
/**
* @ORM\Column(name="created_at", type="datetime")
* @var \DateTimeImmutable
*/
private $createdAt;
/**
* @ORM\Column(name="created_by", type="string")
* @var string
*/
private $createdBy;
// [..]
}
表名和列名都是snake_case
,而类名和属性名都是camelCase
.
我尝试在实体类中删除表名和列名声明,并通过配置提供了命名策略,尝试通过以下两种方式进行设置。
<?php
use Doctrine\ORM\Mapping\UnderscoreNamingStrategy;
return [
'doctrine' => [
'connection' => [
// [..]
],
'driver' => [
// [..]
],
'annotation' => [
// [..]
],
'entity_managers' => [
'default' => [
'naming_strategy' => UnderscoreNamingStrategy::class,
],
],
'orm' => [
'naming_strategy' => UnderscoreNamingStrategy::class,
],
],
];
尝试检索实体时,会引发错误。
Doctrine\DBAL\Exception\InvalidFieldNameException: An exception occurred while executing 'SELECT t0.id AS id_1, t0.createdAt AS createdAt_2, t0.createdBy AS createdBy_3, t0.updatedAt AS updatedAt_4, t0.updatedBy AS updatedBy_5, t0.name AS name_6, t0.desc AS desc_7, t0.isCore AS isCore_8 FROM Role t0':
SQLSTATE[42S22]: Column not found: 1054 Unknown column 't0.createdAt' in 'field list' in file C:\project\path\vendor\doctrine\dbal\lib\Doctrine\DBAL\Driver\AbstractMySQLDriver.php on line 60