RSS Записей | RSS Комментариев
Ядоблог - Stay upwind

Архив ‘HowTo’ Категории

sphinx, xmlpipe2, PHP и MongoDB или загибаем трубу из MongoDB в сфинкс, используя PHP

мая 22, 2012 | Комментариев нет

ТЗ: организовать релевантный поиск.

ТУ: данные хранятся в MongoDB, бэкенд на PHP.
Читать полностью »

Без рубрики IAD

MongoDB удаление атрибута(из массива) внутри объекта.

марта 11, 2011 | Комментариев нет

Продолжаем изучать MongoDB.
На этот раз хитрое удаление.
Допустим имеется коллекция объектов:

Кликабельно

Это сайты, в которых есть поле пользователи и это поле является массивом пользователей этого сайта.
И нам нужно удалить конкретного пользователя в сайте.
Допустим мы знаем site_id и user_id пользователя внутри коллекции пользователей этого сайта.
Реализация:

$where=array('site_id'=>$site_id);
$set=array('$pull'=>array('users'=>array('user_id'=>$user_id)));
$this->db->sites->update($where,$set);

Разберём конструкцию.
$where — ограничиваем множество документов крупным критерием(выбрали сайт по его site_id).
$set — указываем метод(вытянуть) элемент из users(users должно быть массивом(коллекцией)), где user_id у этого элемента наш $user_id.
Красота =)

Удачного дня!

Без рубрики admin

NoSQL. PHP. Реализуем хитрый OR

февраля 24, 2011 | 5 Комментариев

Допустим у нас имеется коллекция сайтов, и, внутри этой коллекции хранятся данные о пользователях сайта, и их правах в этом сайте.Приведу один объект из коллекции, но их у нас много:

Задача: выбрать документы из данной коллекции, где определённый user_id находится или в первом уровне(является владельцем) или в коллекции пользователей этого сайта (является назначенным пользователем и его права определяются дополнительно).

В обычном sql у нас бы не было так вкусно расположенных данных, а было бы 2-3 таблицы связанные таблицами объединяющими их id (много ко многим) и решением было бы сделать крутой джойн или несколько запросов.

Решение в NoSQL (MongoDB, PHP):

//Подконнектимся
$this->connection = new Mongo('localhost:27017');
//Дёрним нужную базу
$this->db = $this->connection->mydb;
//Что будем искать
$user_id='fabe6e3dab8c63bb28a27b98c5c15554';
//Будем искать или сразу в первом уровне user_id или users.user_id.
//Немного непривычная форма формирования условия, но это адапрированный json, через массивы
//Примерно: or (_первое выражение_, _второе выражение_)
$data=array('$or'=>array(array('users.user_id'=>$user_id),array('user_id'=>$user_id)));
//Переберём их по-порядку, т.к. они объекты
$cursor=$this->db->sites->find($data);
$sites=array();
foreach ($cursor as $site)
{
//Сформируем массив таких сайтов удовлетворяющих условию
$sites[]=$site;
}

Согласитесь, красивое и удобное решение?=)

Обратите внимание, что документов в коллекции пользователей разные атрибуты.

Без рубрики IAD

Эпик фейл. Потеря данных в VirtualBox. Данные не сохранялись.

февраля 15, 2011 | Комментариев нет

Столкнулся недавно с проблемой в VirtualBox- выдёргиваешь USB девайс, на котором лежал образ диска, или падает сетка с образом на другом компе и:

1. виртуалка виснет намертво (не решено)

2. Все данные с результатом последних часов работы (с момента запуска виртуалки) — теряются. (решено)

решение как всегда простое — заходим в настройку виртуалки и убираем чекбокс нах!

Без рубрики IAD

CodeIgniter + MongoBD

февраля 11, 2011 | Комментариев нет

Используем MongoDB с CodeIgniter.
Установка. Всё расписано хорошо тут: http://alexbilbie.blogs.lincoln.ac.uk/2010/04/09/mongodb-codeigniter-101-part-1/.
Если у вас Windows:
1. скачайте версию MongoDB для Windows с официального сайта
2. создайте «c:\data\db\» (там монго будет хранить все свои базы)
3. запустите в скачанном архиве mongod — демон монго. Если окошко продолжает висеть, то всё ок — СУБД монги работает.

Теперь настройте PHP:
1. нужно скачать библиотеку монго.
2. скопировать в папку ext и вставляйте в php.ini «extension=php_mongo.dll». В архиве будет много версий файла — смотрите readme и выбирайте нужный.
3. перезапустить апачу. Если апача стартанула, думаю всё хорошо.

Скачайте редактор(менеджер баз данных) для монго:
1. Мне нравится RockMongo — типа phpMyAdmin
2. программа с GUI для виндовс Database Master

Ну, уже хорошо. Можно работать.

Без рубрики IAD
© 2010 Ядоблог. Все права защишены.
Powered by Лаборатория Яда. Написать администратору