Schemaless-базы данных
Nov. 11th, 2015 12:08 pmЯ давно хотел написать этот пост, но до разговора с Фёдором Сигаевым на PGConf.eu стеснялся.
Одно из позиционирований NoSQL-ных баз данных — отсутствие схемы. Я всегда этот момент не понимал. Собственно, у меня на рабочем столе (физическом) полное отсутствие схемы, и помойкой это не является только потому, что я её так не называю. В смысле, мало запихнуть данные в куда-нибудь, с ними надо ещё работать: искать по атрибутам или по их значениям, а значит где-то эти значения должны регламентироваться. Не будут регламентироваться — рано или поздно получите атрибуты topic, Topic и TOPICS с одной семантикой.
В SQL-базе эту регламентацию достигают проверкой на уровне имён колонок. В NoSQL это придётся делать в приложении, потому что альтернатива — в мозгах программистов — слишком ненадёжна. И то и другое приводит к багам разной степени уловимости, даже при использовании hstore мы вдвоём с коллегой по этому грабельному полю потоптались.
То есть по большому счёту летать вся эта структурированность будет в паре случаев.
1. Когда база используется как хранилище без обработки. Максимум - проверить, что то, что передали в качестве XML, таковым является.
2. Когда “структурированные” данные обрабатываются и пишутся локально (например, параметры для разных типов заданий в очереди). И то в этом случае приходится работать с такой структурой как минимум в 2 местах — при чтении и при записи.
Во всех остальных случаях получаются размазанные по приложению метаданные, которые удобней держать в одной точке — в базе. Удобнее, например, потому как grep-ать не надо, а можно описание таблицы посмотреть. Нельзя построить внешние ключи (ну, ORM это частично компенсирует) и навести типизацию тоже можно довольно ограниченно.
Лично я до сих пор использую из таких "бессхемных" типов в PostgreSQL ровно 2 — hstore и XML. XML при этом в моей задаче можно было бы заменить массивом hstore или отдельной таблицей, но из соображений отслеживания изменений оказалось проще внедрить XML. Можно было бы с таким же успехов json воткнуть, впрочем.
Конечно, недооценивать экономию усилий при добавлении новой колонки не надо. Это часто бывает самостоятельным геморроем, особенно если требуется zero downtime. Но пока что, по ощущениям, schemaless того не стоит.
Одно из позиционирований NoSQL-ных баз данных — отсутствие схемы. Я всегда этот момент не понимал. Собственно, у меня на рабочем столе (физическом) полное отсутствие схемы, и помойкой это не является только потому, что я её так не называю. В смысле, мало запихнуть данные в куда-нибудь, с ними надо ещё работать: искать по атрибутам или по их значениям, а значит где-то эти значения должны регламентироваться. Не будут регламентироваться — рано или поздно получите атрибуты topic, Topic и TOPICS с одной семантикой.
В SQL-базе эту регламентацию достигают проверкой на уровне имён колонок. В NoSQL это придётся делать в приложении, потому что альтернатива — в мозгах программистов — слишком ненадёжна. И то и другое приводит к багам разной степени уловимости, даже при использовании hstore мы вдвоём с коллегой по этому грабельному полю потоптались.
То есть по большому счёту летать вся эта структурированность будет в паре случаев.
1. Когда база используется как хранилище без обработки. Максимум - проверить, что то, что передали в качестве XML, таковым является.
2. Когда “структурированные” данные обрабатываются и пишутся локально (например, параметры для разных типов заданий в очереди). И то в этом случае приходится работать с такой структурой как минимум в 2 местах — при чтении и при записи.
Во всех остальных случаях получаются размазанные по приложению метаданные, которые удобней держать в одной точке — в базе. Удобнее, например, потому как grep-ать не надо, а можно описание таблицы посмотреть. Нельзя построить внешние ключи (ну, ORM это частично компенсирует) и навести типизацию тоже можно довольно ограниченно.
Лично я до сих пор использую из таких "бессхемных" типов в PostgreSQL ровно 2 — hstore и XML. XML при этом в моей задаче можно было бы заменить массивом hstore или отдельной таблицей, но из соображений отслеживания изменений оказалось проще внедрить XML. Можно было бы с таким же успехов json воткнуть, впрочем.
Конечно, недооценивать экономию усилий при добавлении новой колонки не надо. Это часто бывает самостоятельным геморроем, особенно если требуется zero downtime. Но пока что, по ощущениям, schemaless того не стоит.
Хм-ммм...
Date: 2015-11-11 09:27 am (UTC)>1. Когда база используется как хранилище без обработки.
Я в этом месте вдруг вспомнил почему-то одну статью на Хабре, где в комментариях упоминали некую файловую систему (название протуканил, хоть убей!), которая пишет быстрее, чем читает.
Там какая-то хитрость была в непрерывном линейном сливе на носитель потока данных в структуру а-ля журнал/лог - отсюда скорость. А вот читалось медленно как раз оттого, что потом драйвер FS был вынужден во всём этом слитом "структур-лесс" (не, конечно, какая-то структурированность и/или реперы там обязаны бвть) великолепии как-то ориентироваться.
Просто "музыкой навеяло"...
С уважением.
no subject
Date: 2015-11-11 09:55 am (UTC)Ты, помнится, когда-то предлагал учить начинающих программистов сперва SQL. Можешь порекомендовать какой-то годный учебник, который ты считаешь достаточно хорошим? На английском тоже подойдет. Желательно, чтоб там было побольше практических заданий.
no subject
Date: 2015-11-11 10:00 am (UTC)Там есть и ответы на вопросы зачем нужны неполно структурированные модели данных и когда их надо/можно применять.
no subject
Date: 2015-11-11 10:01 am (UTC)no subject
Date: 2015-11-11 10:40 am (UTC)no subject
Date: 2015-11-11 10:49 am (UTC)Модель «Сущность-атрибут-значение» (EAV) 40
Неполно структурированные модели данных 49
Документ-ориентированная модель и NoSQL 52
Многомерные модели данных 57
О применимости NoSQL 61
Множественная и навигационная обработка, менеджеры записей 66
Объектная модель и объектно-реляционная проекция 70
SQL как универсальный входной язык 80
...
Неполно структурированные данные и высокая нагрузка 173
Относительность понятия высокой нагрузки 173
Особенности использования РСУБД и НСМД (NoSQL) 175
...
РСУБД и неполно структурированные данные 249
Поддержка XML 250
Поддержка JSON 258
no subject
Date: 2015-11-11 10:09 am (UTC)no subject
Date: 2015-11-11 10:14 am (UTC)Но мне там уже выше порекомендовали :)
no subject
Date: 2015-11-11 10:31 am (UTC)no subject
Date: 2015-11-11 10:32 am (UTC)no subject
Date: 2015-11-11 10:20 am (UTC)В какой-то древней книжке, где обсуждались особенности синтаксиса Алгола-60 (!), и которую я читал, когда программировал на PL-1, говорилось с сожалением о том, что нету, нету у "нынешних" программистов на языке высокого уровня достаточной дисциплины мышления! Что им нужен внешний дисциплинирующий фактор, НАПРИМЕР, на уровне синтаксиса языка.
:)
no subject
Date: 2015-11-11 06:19 pm (UTC)no subject
Date: 2015-11-11 10:21 am (UTC)... Эх, Додоша, а ещё математик ...
no subject
Date: 2015-11-11 10:32 am (UTC)no subject
Date: 2015-11-11 10:50 am (UTC)Данные в неглиже, тсзать.
!
Date: 2015-11-11 11:19 am (UTC)Это ещё цветочки - я с налёта вообще прочёл как "shemale"... Во где жЭсть-то! :)))
С уважением.
no subject
Date: 2015-11-11 11:46 am (UTC)no subject
Date: 2015-11-11 12:06 pm (UTC)no subject
Date: 2015-11-11 10:58 am (UTC)no subject
Date: 2015-11-11 11:44 am (UTC)no subject
Date: 2015-11-11 01:09 pm (UTC)Зачем в мозгах, в тетрадочке же!
На позапрошлой работе была священная черная тетрадочка, в которой были структуры всех таблиц (mumps, если что). Потом оттуда ушел я, еще через полгодика - все остальные, потом туда взяли новых программистов, а новые программисты позвали меня - разбирать коды программ и рисовать им утраченные схемы :)
no subject
Date: 2015-11-11 01:43 pm (UTC)И ничего вычислительно более дешевое, чем полнотекстовый поиск (в идеале с подключением словаря синонимов, но это уже дороже), для работы тупо не годится.
no subject
Date: 2015-11-11 02:17 pm (UTC)no subject
Date: 2015-11-11 03:17 pm (UTC)no subject
Date: 2015-11-11 05:08 pm (UTC)no subject
Date: 2015-11-12 04:20 pm (UTC)И это редкий пример NoSQL, которые реально имеют смысл )
no subject
Date: 2015-11-11 04:46 pm (UTC)а) я динозавр
б) it's blazingly fast
no subject
Date: 2015-11-11 05:07 pm (UTC)— 2000 символов в минуту, но такая фигня получается...
no subject
Date: 2015-11-12 01:06 am (UTC)В этом случае в "неструктурированную БД" пишется только сериализация объектов, тогда нет проблемы с "черной книжечкой" или памятью программистов, все вполне однозначно и гарантировано документировано. Там есть некоторые хитрости, но простые.
А в качестве движка для неструктурированных данных - лучше всего, разумеется, json/jsonb в том же PostgreSQL.
no subject
Date: 2015-11-12 04:31 am (UTC)no subject
Date: 2015-11-12 08:08 am (UTC)Для AppLayer - все там жестко структурировано, DAO layer работает только с полноценными объектами (и при таком подходе всякие ORM лишаются смысла, к счастью).
Для PersistanceLayer (собственно СУБД) мы сохраняем нормализацию - содержимое json является неделимым на уровне СУБД.
Единственное, что часть значимых для поиска полей из json вытаскиваем в нормальные колонки и строим индексы. Да, теоретически можно делать индексы и по jsonb, но я вот пока не готов так делать.
Но если мне когда-нибудь понадобиться какой-нибудь экзотический отчет на уровне СУБД - то я знаю, что я смогу его сделать через доступ к json-содержимому.
И производительность, конечно, гораздо выше, чем если бы я нормализовал все содержимое json и хранил 100500 колонок и табличек.