MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Doktryna ODM i projektowanie bez schematów

Rozwiązaniem jest użycie @Hash

Oto BARDZO podstawowy przykład, który zrobiłem:

<?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;
    }

}

Dodaj trochę danych:

<?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();

Następnie zapytaj, znajdź produkt w kolorze „Czarny” i rozmiarze ekranu większym niż 20:

<?php

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

Nadal nie jestem pewien, czy jest to najlepszy sposób na zrobienie tego, a moje badania nadal trwają.



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak zwrócić wartości wariantów każdego produktu, jeśli ten produkt jest wariantem?

  2. mongo znajdź zapytanie na joda datetime

  3. jak znaleźć tablicę wartości w agregacji $match i pogrupować wynik?

  4. Mongoose tablica schematów obiektów

  5. MongoDB:zapytanie o pole