Auto Increment with MongoDB
Популярная по своей дурости задача «а я не хочу эти длинные id, я хочу увеличивающиеся циферки в качестве айдишников».
Несмотря на свою нелепость, она иногда нужна. Например, человекочитаемые номера. «Хуйня номер 10».
Самый простой и рекомендуемый всеми способ — хранить где-то отдельно счетчик и менять его с помощью findandmodify (для чего в php нет отдельного метода, но можно через command).
Но можно сделать проще!
Если это хорошая, правильная таблица, из которой ничего не удаляется, то мы можем посчитать «номер записи» в таблице тупо зная тот факт, что нативные MongoId увеличиваются со временем и по ним можно сортировать не хуже, чем по какой-нибудь «дате создания».
Короче, как-то так:
$mongo -> insert ($U);
$inc = $mongo -> find (array ("_id" => array ('$lt' => $U[_id])));
$inc = $inc -> count ();
$inc++;
$mongo -> update (array ("_id" => new MongoId ($U[_id])), array ('$set' => array ("inc" => $inc)));
Ограничения очевидны, но часто «и так сойдет», да-да.
Фотосортер
Поставил сначала Пикасу. Потом подумал и написал скрипт (вы не поверите — на php), который сортирует все фотографии по директориям, вида год/название камеры/месяц.
Отсортировал все за десять лет.
Оказалось очень удобно, особенно название камеры, сразу видны профессиональные фотосессии и хипстерские фотки с айфона.
Ну и что-то лучше, чем сортировки по годам сложно представить.
Заодно думаю о покупке Canon PowerShot S100, потому что PowerShot G5 уже старенький (и он за эти годы не уменьшился).
$Directory = new RecursiveDirectoryIterator($from); foreach ($Iterator as $key => $value) $exif = @exif_read_data($key); $dest = "";
if (!$exif[FileDateTime]) if ($exif[Model]) $dest.="/".$path[basename]; echo $c.".".$key." -> ".$dest." $newpath = pathinfo ($dest); $newpath = pathinfo ($copydest); }
/*
$from = "D:\acerbial_media";
$to = "P:";
$copy = "D:\photos";
*/
$Iterator = new RecursiveIteratorIterator($Directory);
{
$path = pathinfo ($key);
if ($exif[Model]=="iPhone 4") $exif[Model]="iPhone";
$dest.="/misc/".$path[extension];
else
$dest.="/".date ("Y",$exif[FileDateTime]);
{
$dest.= "/{$exif[Model]}";
$dest.="/".date ("m.F",$exif[FileDateTime]);
}
$dest = str_replace ('//','/',$dest);
$copydest = $copy.$dest;
$dest = $to.$dest;
";
$c++;
@mkdir ($newpath[dirname],0777,true);
copy ($key,$dest);
@mkdir ($newpath[dirname],0777,true);
rename ($key,$copydest);
Php maed me sad
ЧПУ sucks balls
ЧеловекоПонятные Урлы — это фетиш.
Я буду отказываться от них везде, где можно. В урле, типа www.hobius.com/?user=smirnov я не вижу ничего плохого, например.
Особенно когда по адресу site.com/users/ нет ничего, а по адресу site.com/users/username уже есть.
Ну и заодно, по аналогии с «твиттерскими» адресами, типа twitter.com/#/something, придумал самый простой способ реализовать ЧПУ почти везде безо всяких mod_rewrite и прочего.
Надо вместо таких урлов:
spectator.ru/life/fiction/blue_meteorite
Делать вот такие:
spectator.ru/?/life/fiction/blue_meteorite
Тогда, например, в php мы все получаем в $_SERVER["QUERY_STRING"].