0

我正在尝试连接 2 个实体,但遇到了麻烦。我有两个类:用户和性别。每个用户都来自一种性别(男性或女性)。在我的数据库中,我有两个具有这种结构的表:

 user(**id**, firstName, gender);
 gender(**id**, type);

现在我在我的系统中创建了两个实体。User.php 和 Gender.php

用户

<?php  

/**
 * @Entity @Table(name="User")
 **/

class User
{
/**
 * @Id @Column(type="integer") @GeneratedValue
 **/  
private $id;

 /**
 * @Column(type="string")
 **/
private $firstName;

 /**
 * @Column(type="string")
 * @ManyToOne(targetEntity="Gender")
 * @JoinColumn(name="type", referencedColumnName="type")
 * @var Gender[]
 **/
private $gender;

 
public function __construct($content) {
    $this->setContent($content);
}   


/**
 * @return int
 */
public function getId() {
    return $this->id;
}
 
/**
 * @return string
 */
public function getFirstName() {
    return $this->firstName;
}

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

/**
 * @param string $content
 */
public function setFirstName($content) {
    $this->firstName = (string) $content;
}

/**
 * @param string $content
 */
public function setGender($content) {
    $this->gender = (string) $content;
}
 
}

性别

<?php  

/**
 * @Entity @Table(name="Gender")
 **/

class Gender
{
/**
 * @Id @Column(type="integer") @GeneratedValue
 **/  
private $id;

 /**
 * @OneToMany(targetEntity="User", inversedBy="gender")
 * @JoinColumn(name="gender", referencedColumnName="gender")
 * @Column(type="string")
 **/
private $type;


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

/**
 * @param string $content
 * 
 */
public function getType() {
    return $this->type;
}


/**
 * @param string $content
 */
public function setGender($content) {
    $this->gender = (string) $content;
}
 
}

我想要的是在获得用户时获得性别类型,因此两个实体都必须通过性别类型属性连接。我曾尝试使用@ManyToOne@JoinColumn功能这样做,但我无法获得它。

我该怎么做?我做错了什么?谢谢!

4

3 回答 3

0

可能是题外话,但性别表是无用的。您将永远只有 2 个(男性/女性),所以这样做没有意义。

您应该在 User 表中创建新列,type=integer 并使用 0/1 作为性别。使用常量,如

Class User
{
   const MALE=0 ;
   const FEMALE=1 ;

  .... ORM definition...

 public function isMale()
 {
     return $this->getGender() == self::MALE ;
 }

在控制器中:

if ( !$user->isMale() ) {
    .... buy shoes ....
} else {
    .... buy beer ....
}

或类似的。因为您只有 2 个选项,所以只需要一个函数。

于 2012-07-19T07:40:27.543 回答
0

在用户类中替换它:

* @JoinColumn(name="type", referencedColumnName="type")

接着就,随即 :

 * @JoinColumn(name="gender", referencedColumnName="type")

您的字段名称是性别,而不是在用户表中输入。

仅在 Gender 类中使用:

 * @OneToMany(targetEntity="User", mappedBy="gender")
于 2012-07-18T18:25:38.000 回答
0

You have to join the gender relation if you want to get if from the query.

$dql = "SELECT a,g FROM user a LEFT JOIN a.gender g";
$query = $em->createQuery($dql);
$query->setMaxResults(30);
$users = $query->getResult();
于 2012-07-19T17:00:03.577 回答