Где почитать про проектирование баз данных(nosql) с практическими примерами?
Здравствуйте, ребята. Я преимущественно разрабатываю приложения, используя нереляционные базы данных, хотя иногда и приходится касаться и реляционных. Хотелось бы найти такой ресурс, где кратко и понятно разобраны принципы архитектурного проектирования приложений, используя nosql-базы. К примеру, было бы очень удобно посмотреть на разбор того, как наиболее правильно хранить пользовательские данные, комментарии, лайки, медиа-данные. Вспомните любую социальную сеть, где над каждым постом есть куча комментариев, лайков, репостов - хотелось бы увидеть реализации или хотя бы наглядную теорио о том, как это(и другие подобные случаи) реализовать правильно. Спасибо!
Читал на хабре подобное и девелопер опускал нереляционки там, где может потребоваться фильтрация , анализ, группировки и тп. В результате из той статьи я для себя сделал вывод, что не стоит пытаться из документной бд выстроить реляционную. Ссылку к сожалению сейчас не найду.
Виталий: не знаю про какую статью речь, но это не повод покупать трактор для поездок по городу с мыслью что когда-нибудь надо будет пахать поле.
На старте надо максимально просчитать необходимое, а когда понадобится то чего нет, уже думать исходя из имеющегося. Поэтому часто в больших проектах можно увидеть зоопарк разных (конкурирующих) технологий вместе.
монго всё это умеет. Единственное преимущество рсубд это транзакции и джойны, которые исчезнут как только сделаешь шардинг базы и нужно кучу кода писать для шардинга. рсубд это вообще не про веб, они появились задолго до веба. Это все более-менее как-то работает только на одной машине, дальше будет боль и никаких преимуществ перед nosql решениями.
Некие джойны есть и в монге, а например в OrientDB есть транзакции, джойны, ссылки и т.п.
В движке монги (wiredTiger) есть транзакции, есть и в плане, возможно и в самой монге появятся.
В итоге рсубд лишь отличается методом хранения который не является идеалом.
Поэтому все БД можно свалить в одну кучу и выбирать по фичам.
lega: не так давно начал работать с ретфинк, все вроде круто, но как только дошло до больших объемов, скорость упала на порядок на некоторых операциях. Sql хаит только глупец. Без обид.
Виталий: никто тут и не хаит sql (и рсубд), sql даже в некоторых nosql используется.
А вот большие объёмы, это как раз не про рсубд зачастую.
> скорость упала на порядок на некоторых операциях
я часто видел бенчмарки где обвиняли в тормозах очередную БД, хотя дело в кривых тестах. Может нет нужного индекса или не хватает памяти или ещё что (внешние силы), нужно искать причину.