php怎么处理一对多,php - 如何处理内部连接以及与OOP的一对多关系? - SO中文参考 - www.soinside.com...

假设我有一个作者和文章表。一篇文章可以有很多作者。所以这是一对多关系。我创建了一个文章类和一个作者类。

class author

{

private $id;

private $name;

public function __construct($array)

{

foreach($array...

}

// getters...

// setters...

}

class article

{

private $id;

private $title;

private $content;

private $author = array();

public function __construct($array)

{

foreach($array...

}

// getters...

// setters...

public function setAuthor(author $author)

{

$this->author[] = $author;

}

}

注意setAuthor,一个setter依赖注入。它需要一个作者对象来保持一对多的关系(一篇文章,许多作者)。

我从数据库中检索了一篇文章。

$sql = $db->prepare("SELECT article.id AS id_article, title, content,

GROUP_CONCAT(author.id SEPARATOR ';') AS id_author,

GROUP_CONCAT(name SEPARATOR ';') AS name FROM article ar

INNER JOIN author au ON ar.id=au.article_id

WHERE article.id=:id GROUP BY article.id");

$sql->bindValue(':id', $id, PDO::PARAM_INT);

sql->execute();

$fromDb = $sql->fetch();

现在我必须构建对象,对吗?

$article['id'] = $fromDb['id_article'];

$article['title'] = $fromDb['title'];

$article['content'] = $fromDb['content'];

$id_author = explode(';', $fromDb['id_author']);

$name = explode(';', $fromDb['name']);

$newArticle = new article($article);

foreach($id_author as $key => $value)

{

$author['id'] = $value;

$author['name'] = $name[$key];

$newArticle->setAuthor(new author($author));

}

我发现最后一部分很重,不实用。我不确定这是正确的做法。许多关系都会出现同样的问题。

在这种特殊情况下,一旦从db获取数据,如何使用对象?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值