gpt4 book ai didi

mongodb - 原则 ODM 和无模式设计

转载 作者:IT老高 更新时间:2023-10-28 13:37:29 27 4
gpt4 key购买 nike

继续我关于 EAV 的问题,我正在考虑使用MongoDB来存储产品属性。<​​/p>

我将使用 MongoDB(或其他文档数据库)存储此应用程序的目录部分 - 类别、产品及其所有相关信息。

我的问题是,当使用 ODM ,每个实体都有一个模式,这基本上忽略了使用 NoSQL 数据库的无模式优势,不是吗?

如果这是正确的,为什么有人会使用 ODM?

编辑:我找到了 related question ,我可以使用哈希来实现产品属性功能吗?

最佳答案

解决方案是使用@Hash

这是我做的一个非常基本的例子:

<?php

/**
* @Document
*/
class Product
{

/**
* @Id
*/
private $id;

/**
* @String
*/
private $name;

/**
* @Hash
*/
private $attributes = array();

public function getId()
{
return $this->id;
}

public function setName($name)
{
$this->name = $name;
}

public function getName()
{
return $this->name;
}

public function addAttribute($name, $value)
{
$key = preg_replace('/[^a-z0-9\ \_]/i', '', $name);
$key = preg_replace('/\s+/i', '_', $key);
$key = strtolower($key);
$this->attributes[$key] = array('value' =>$value, 'label' => $name);
}

public function getAttribute($name)
{
return $this->attributes[$name];
}

public function getAttributes()
{
return $this->attributes;
}

}

添加一些数据:

<?php

$pen = new Product();
$pen->setName('Cool Pen');
$pen->addAttribute('Weight', 12);
$pen->addAttribute('Ink Colour', 'Red');
$pen->addAttribute('Colour', 'Black');

$tv = new Product();
$tv->setName('LED LCD TV');
$tv->addAttribute('Weight', 12550);
$tv->addAttribute('Screen Size', 32);
$tv->addAttribute('Colour', 'Black');

$dm->persist($pen);
$dm->persist($tv);

$dm->flush();

然后查询,找到颜色为“黑色”且屏幕尺寸大于20的产品:

<?php

$query = $dm->createQueryBuilder('Catalogue\Product');
$products = $query->field('attributes.colour.value')->equals('Black')
->field('attributes.screen_size.value')->gte(20)
->getQuery()->execute();

我仍然不确定这是否是最好的方法,我的研究仍在进行中。

关于mongodb - 原则 ODM 和无模式设计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5306622/

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