Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.84/19: Рейтинг темы: голосов - 19, средняя оценка - 4.84
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421

Реализация базы данных на текстовых файлах без сторонней СУБД

18.04.2023, 23:57. Показов 5625. Ответов 66
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброй ночи!
Какие есть подходы к ведению базы данных в текстовых файлах, когда не нужна СУБД, и каких распространённых ошибок следует избегать при её проектировании?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.04.2023, 23:57
Ответы с готовыми решениями:

Реализация базы данных средствами «Словарь морфем английского языка» СУБД Microsoft Access
Отредактируйте структуру базы данных: в базу данных добавьте следующую информацию: иностранный язык, которым владеет каждый менеджер, адрес...

Выбор CMS без базы данных (на файлах)
Здраствуйте. Помогите выбрать хороший движок для сайта, для работы которого не нужна база данных, то есть, так называемую, CMS на...

Реализация базы данных на С# без ADO.net и SQL серверов
Здравствуйте уважаемые участники форума. Мне была поставлена задача создать реализацию базы данных без использования SQL сервера и других...

66
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
20.04.2023, 16:15  [ТС]
Студворк — интернет-сервис помощи студентам
В том и едло, что мой вопросне привязан к одному конкретному проекту, а рассматривает общий подход к решению задач.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
20.04.2023, 16:24
Так вы попробуйте придумать ситуацию.
Что за ситуация вообще такая,хоть примерно опишите.
Почему нельзя использовать СУБД?
Что требуется от БД (хранение, поиск, обеспечение целостности и т.д и т.п.)?

Если со всем для "общего случая". То разработчик должен на очень хорошем уровне знать как работают СУБД. Глубоко погрузиться в этот вопрос и т.п. На практике возможность возникновения такой ситуации пренебрежительно мала. Вопросов придется решать до фига и больше. В т.ч. и структура "текстового" файла. Формат вам все равно придется придумывать, так что это не будет "текстовый файл".
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
20.04.2023, 22:20  [ТС]
Любой файл - текстовый. Разница - в представлении данных. Если бы я мог описать ситуацию, я бы давно сам придумал решение, а так меня интересуют грабли, на которые приходилось наступать тем, кто это делал до меня. Для простоты будем считать, что я делаю клон киберфорума.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
21.04.2023, 01:06
Цитата Сообщение от TrueTyper Посмотреть сообщение
Для простоты будем считать, что я делаю клон киберфорума
Ну вот для ориентира если взять что для создания форума вам требуется Х часов, то для создания "своего" решения заменяющего СУБД в той мере, что нужно для функционирования этого форума, вам надо X*10 часов. Тоже самое со скилами. Ни кто во вменяемом состоянии не будет этого делать.

Подводные камни.... ну тут просто изучите одну из СУБД (тот же MySQL) глубоко. Т.е. как организуется совместный доступ, транзакции, ключи, индексирование, блокировки различных уровней, кеширование. Т.е. тут я бы говорил не о "подводных" камнях, а о серьезных знаниях которые надо получить, чтобы браться за эту задачу.

При этом тут надо понимать, что PHP не подходящий вариант для этого.

В итоге, ну так сделать можно для развлечения и прокачки навыков... но серьезно для проекта - нет.

Добавлено через 1 минуту
Цитата Сообщение от TrueTyper Посмотреть сообщение
, на которые приходилось наступать тем, кто это делал до меня
Так что если кто то делал, в большинстве случаев, это было не серьезно и без достаточных знаний и умений - это и есть основные грабли
0
 Аватар для vantfiles
1018 / 1921 / 177
Регистрация: 07.05.2013
Сообщений: 3,931
Записей в блоге: 12
21.04.2023, 11:09
Цитата Сообщение от TrueTyper Посмотреть сообщение
каких распространённых ошибок следует избегать при её проектировании?
Если данные хранятся в текстовых файлах, то следует предусмотреть защиту данных при записи.
Не писать данные сразу в основной рабочий файл, а создавать дубликат - и затем копировать его в основной файл.
Даже если на каком-то этапе выключится свет, данные не потеряются.

Текстовая база оправдывает себя тогда, когда данные имеют простую структуру, в этом случае чтение/запись + парсинг/сериализация одной записи-файла происходит в разы быстрее чем в случае использования бд.

Из практики. Игровой профиль. Размер файла в среднем 50 кб. Возникла мысль загнать игровые профили в базу. Зацепил SQLite, расписал таблички, померял время записи. 0.1 сек против 0.0001 на плайн-тексте. Если 50 игроков одновременно сделают запись профиля, лаг бы составил 5 секунд.
1
Модератор
 Аватар для D1973
9944 / 6479 / 2460
Регистрация: 21.01.2014
Сообщений: 27,461
Записей в блоге: 3
21.04.2023, 11:20
Цитата Сообщение от vantfiles Посмотреть сообщение
Если 50 игроков одновременно сделают запись профиля, лаг бы составил 5 секунд.
Далеко не факт. А с учетом того, что при использовании текстовика это было бы вообще невозможно, то...
0
 Аватар для vantfiles
1018 / 1921 / 177
Регистрация: 07.05.2013
Сообщений: 3,931
Записей в блоге: 12
21.04.2023, 11:46
Цитата Сообщение от D1973 Посмотреть сообщение
это было бы вообще невозможно
что невозможно?
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12235 / 5082 / 814
Регистрация: 07.08.2010
Сообщений: 14,953
Записей в блоге: 4
21.04.2023, 13:16
Цитата Сообщение от vantfiles Посмотреть сообщение
что невозможно?
одномоментная запись в текстовик сообщений от нескольких пользователей
1
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
21.04.2023, 13:24
Цитата Сообщение от shanemac51 Посмотреть сообщение
одномоментная запись в текстовик сообщений от нескольких пользователей
"Просто" реализовывать очередь команд
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12235 / 5082 / 814
Регистрация: 07.08.2010
Сообщений: 14,953
Записей в блоге: 4
21.04.2023, 13:33
Цитата Сообщение от voral Посмотреть сообщение
"Просто" реализовывать очередь команд
хотелось бы увидеть вашу реализацию, хотя бы упрощенно, на уровне макета
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
21.04.2023, 13:39
Цитата Сообщение от shanemac51 Посмотреть сообщение
хотелось бы увидеть вашу реализацию, упрощенно, на уровне макета
Обратите внимание на кавычки обрамляющие слово "просто"

По сути, тут придется работать в памяти, например в мемкеше (ТС отмечался в темах по PHP) пишем туда в очередь, очередь обрабатывается постепенно. Тут придется мудрить примерно как в том же мускуле - процесс засыпает пока запись залочена.
0
 Аватар для vantfiles
1018 / 1921 / 177
Регистрация: 07.05.2013
Сообщений: 3,931
Записей в блоге: 12
21.04.2023, 13:40
Цитата Сообщение от shanemac51 Посмотреть сообщение
одномоментная запись в текстовик сообщений от нескольких пользователей
На каждого пользователя - свой отдельный текстовый файл. В этом то и смысл.
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12235 / 5082 / 814
Регистрация: 07.08.2010
Сообщений: 14,953
Записей в блоге: 4
21.04.2023, 13:50
Цитата Сообщение от vantfiles Посмотреть сообщение
На каждого пользователя - свой отдельный текстовый файл. В этом то и смысл.
остается только решить, как перевести их в хронологический текстовик и отсортировать по дате+время+пользователь для
- отчетов по загрузке
- когда был последний раз
...

хотя иногда сообщение надо корректировать(как и на любом форуме) или удалить или дать ссылку
0
 Аватар для volodin661
7092 / 2323 / 352
Регистрация: 10.12.2013
Сообщений: 8,007
21.04.2023, 13:52
Цитата Сообщение от shanemac51 Посмотреть сообщение
одномоментная запись в текстовик сообщений от нескольких пользователей
учётной единицей в ОС является Process
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12235 / 5082 / 814
Регистрация: 07.08.2010
Сообщений: 14,953
Записей в блоге: 4
21.04.2023, 14:03
хотя иногда сообщение надо корректировать(как и на любом форуме) или удалить или дать ссылку
конечно иногда надо реализовать
- диалог - как например в скайпе
- или ввести/скорректировать запись в справочник , например переименовать Калинин

текстовая база only read - только на выборку с элементами поиска вполне решаема, но вряд ли в текстовом виде есть смысл делать базу Продажи с приходными/расходными накладными и дюжиной справочников, еще больше отчетов
1
 Аватар для vantfiles
1018 / 1921 / 177
Регистрация: 07.05.2013
Сообщений: 3,931
Записей в блоге: 12
21.04.2023, 14:47
Цитата Сообщение от shanemac51 Посмотреть сообщение
- отчетов по загрузке
- когда был последний раз
Для этого просто ведется отдельный лог-файл.
Cчитывается и парсится он за 0.4-0.5 сек чтоль... Щас не помню точно.
Самая долгая операция сейчас - это верификация данных в профилях. Для 17500 пользователей она длится 2 сек.

Добавлено через 1 минуту
Цитата Сообщение от shanemac51 Посмотреть сообщение
Продажи с приходными/расходными накладными и дюжиной справочников, еще больше отчетов
Разумеется. Там где появляются ссылки, перекрестные ссылки - тексту делать нечего.
0
 Аватар для VinniPuh
9147 / 6176 / 594
Регистрация: 27.03.2013
Сообщений: 20,046
21.04.2023, 17:15
Жесть.
Посмотрел для интереса профить ТСа.
Ни одного положительного отзыва.
Кликните здесь для просмотра всего текста
Как таким говном можно жить?
Ну не опарыш же.
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
21.04.2023, 17:28  [ТС]
А если я закэширую декартово произведение в отдельных файлах, то задача решаемая.

Добавлено через 3 минуты
VinniPuh, это - бескровная жертва ради кресла директора Сбербанка.

Добавлено через 5 минут
alhaos, твой sqlite перестанут поддерживать, и ты будешь переписывать весь слой работы с данными.

Добавлено через 1 минуту
voral, в современной науке уже никто не читает миллиард статей в день, а придумывают и доказывают всё с нуля - так быстрее.
0
 Аватар для VinniPuh
9147 / 6176 / 594
Регистрация: 27.03.2013
Сообщений: 20,046
21.04.2023, 17:35
TrueTyper, не стал -1000 ставить, ибо тоже будучи студентом ночью кричал в форточку , что бы халява пришла.
Так что расслабь очко.
Если хамить и матом прилюдно не будешь ругаться, я минусовать не стану как некоторые.
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
21.04.2023, 17:46  [ТС]
VinniPuh, так поставь. Мне всё равно. Эти оценки характеризуют тех, кто их ставил.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.04.2023, 17:46

Сравнение данных в текстовых файлах
Добрый день! Кто может помогите пожалуйста в написании программы по верификации файлов. Дали задание на работе написать программу, а...

База данных на текстовых файлах
Здравствуйте ! Создал класс текстовой базы данных inidb. Что можете о нём сказать ?

ОРГАНИЗАЦИЯ ФАЙЛОВОЙ СИСТЕМЫ. ОБРАБОТКА ТЕКСТОВЫХ ФАЙЛОВ. ТИПИЗИРОВАННЫЕ ФАЙЛЫ. ФАЙЛЫ БЕЗ ТИПА. СОЗДАНИЕ БАЗЫ ДАННЫХ.
Разработайте программу для работы с текстовым файлом, содержащую следующие пункты меню: − создание и заполнение файла; ...

Какая СУБД хранит данные в файлах с расширением .dat и индексы в файлах .k01, k02 и т.д.?
Какая СУБД хранит данные в файлах с расширением .dat и индексы в файлах .k01, k02 и т.д.? Есть ли возможность подключить эти таблицы в MS...

Реализация отправки данных из EditText приложения Android в поле таблицы БД под СУБД Oracle 11g и в поле БД под СУБД MSSQL
всем доброго времени суток! Читаю и изучаю мануалы и уроки по разработке ПО под Андройд. вообщем постоянно крутиться мысль в голове,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
Новые блоги и статьи
Сезонность и суточность закисления почв
anaschu 04.07.2026
200 часов это все равно моловато. Есть ситуации, но нестандартные, когда смена происходит за 5 лет. Но обычно это 50 лет и более. Наверное, закисление почвы происходит сезонно в средней. . .
В чем ценность человеческого опыта в глобальном смысле?
kumehtar 03.07.2026
Возможно, ценность человека не в том, что он однажды достигает мудрости, а в том, что он становится носителем карты пути. Он знает не только истину, но и последовательность внутренних изменений,. . .
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru