gpt4 book ai didi

php - 如何在 symfony 中为枚举生成实体和模式

转载 作者:IT王子 更新时间:2023-10-29 00:09:49 25 4
gpt4 key购买 nike

我正在尝试为我的联系信息生成实体。为此,我首先在创建一个枚举字段的地方使用以下语法创建实体。

php app/console doctrine:generate:entity --entity="BannerTestBundle.contact" --fields="name:string(255) lastname:string(255) phone:integer(10) gender:enum("male","female") message:text".

上面的命令生成了实体类,但是当我试图从类中生成“实体”时,它会显示命令错误。

 php app/console doctrine:generate:entities Banner/TestBundle/Entity/contact

它将显示以下错误。

[Doctrine\Common\Annotations\AnnotationException]
[Semantical Error] Couldn't find constant male, property Banner\TestBundle\
Entity\contact::$gender.

doctrine:generate:entities [--path="..."] [--no-backup] name

我想生成包含以下字段的数据库:

Contact.table
Name-string(255)
LastName-string(255)
Phone:integer(10)
gender:enum("male","female")
message:text

请帮助我,因为我是 symfony 的新手

这是联系实体文件

 <?php

namespace Banner\TestBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
* contact
*
* @ORM\Table()
* @ORM\Entity(repositoryClass="Banner\TestBundle\Entity\contactRepository")
*/
class contact
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;

/**
* @var string
*
* @ORM\Column(name="name", type="string", length=255)
*/
private $name;

/**
* @var string
*
* @ORM\Column(name="lastname", type="string", length=255)
*/
private $lastname;

/**
* @var enum
*
* @ORM\Column(name="gender", type="enum", length=male,female)
*/
private $gender;

/**
* @var integer
*
* @ORM\Column(name="phone", type="integer", length=12)
*/
private $phone;

/**
* @var string
*
* @ORM\Column(name="message", type="text")
*/
private $message;


/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}

/**
* Set name
*
* @param string $name
* @return contact
*/
public function setName($name)
{
$this->name = $name;

return $this;
}

/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}

/**
* Set lastname
*
* @param string $lastname
* @return contact
*/
public function setLastname($lastname)
{
$this->lastname = $lastname;

return $this;
}

/**
* Get lastname
*
* @return string
*/
public function getLastname()
{
return $this->lastname;
}

/**
* Set gender
*
* @param \enum $gender
* @return contact
*/
public function setGender(\enum $gender)
{
$this->gender = $gender;

return $this;
}

/**
* Get gender
*
* @return \enum
*/
public function getGender()
{
return $this->gender;
}

/**
* Set phone
*
* @param integer $phone
* @return contact
*/
public function setPhone($phone)
{
$this->phone = $phone;

return $this;
}

/**
* Get phone
*
* @return integer
*/
public function getPhone()
{
return $this->phone;
}

/**
* Set message
*
* @param string $message
* @return contact
*/
public function setMessage($message)
{
$this->message = $message;

return $this;
}

/**
* Get message
*
* @return string
*/
public function getMessage()
{
return $this->message;
}
}

最佳答案

您的注释格式不正确。试试这个:

@ORM\Column(name="gender", type="string", columnDefinition="enum('male', 'femelle')")

不要忘记添加

mapping_types:
enum: string

下面

doctrine:
dbal:
driver: %database_driver%
host: %database_host%
port: %database_port%
dbname: %database_name%
user: %database_user%
password: %database_password%
charset: UTF8

app/config/config.yml 文件中。

关于学说中枚举的更多信息 here .

关于php - 如何在 symfony 中为枚举生成实体和模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14933228/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com