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

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

18.04.2023, 23:57. Показов 5621. Ответов 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
 Аватар для VinniPuh
9147 / 6176 / 594
Регистрация: 27.03.2013
Сообщений: 20,046
21.04.2023, 17:54
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от TrueTyper Посмотреть сообщение
так поставь
Если по мне, то ты ни чего противоестественного не сотворил.
Вот если прилюдно матерно ругнешся, то тут я в первых рядах буду.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
21.04.2023, 21:09
Цитата Сообщение от TrueTyper Посмотреть сообщение
alhaos, твой sqlite перестанут поддерживать, и ты будешь переписывать весь слой работы с
данными.
Если учился плохо, то возможно.
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
21.04.2023, 23:36  [ТС]
Цитата Сообщение от voral Посмотреть сообщение
Если учился плохо, то возможно.

Не по теме:

Да, те, кто хорошо учились, могут создать базу из чего угодно.



Добавлено через 36 секунд
VinniPuh, я так не делаю нигде.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 07:46
TrueTyper, я не про базу. Если вы пишете проект правильно у вас не будет непосредственная работа с источником данных (в т.ч. с бд) размазана по всему проекту. Т.е даже если вдруг sqlLite прекратит свое существование (что маловероятно) если вы все правильно построили то вам потребуется написать только один класс имплементирующий определенный интерфейс в вашем проекте и указать что дальше надо использовать именно его.

Цитата Сообщение от TrueTyper Посмотреть сообщение
Да, те, кто хорошо учились, могут создать базу из чего угодно.
Могут и будут создавать разные вещи. Полноценная замена СУБД это огромная серьезная задача в которой придется решить массу вопросов. В вашем же случае я рекомендую в первую очередь научиться разбираться в вопросе о целесообразности создания своего решения. Если взять вашу задачу предложенную для примера (создать аналог этого форума) - это крайне не правильное решение. Т.е. случаи когда объективно подходит хранение в текстовых файлах это, можно сказать, специфичные случаи. Т.е. когда конкретно в конкретной задаче вы понимаете, что вам не нужна работа с БД. Но тут нет смысла вообще обсуждать подводные камни в отрыве от конкретики задачи. (как пример обсуждение выше)

В реальном же мире могу пример привести с MySQL. в виду определенных событий (Oracle поглотила Sun и имела свое видение лицензионной политики) появились форки MariaDB и Percona MySQL . sqlLite тоже имеет открытый исходный код ни какого кода переписывать не пришлось.
1
Эксперт MS Access
 Аватар для ltv_1953
17536 / 7288 / 1663
Регистрация: 21.06.2012
Сообщений: 13,957
22.04.2023, 08:30
Когда то давно (БД не было) были информационно-поисковые системы. Писали их на Коболе, PL/I, Ассемблере ... . Занятие было унылое. Хотите пойти по этому пути - вперед, конкретную задачу решите наверняка, но универсальным это решение не будет.

Не по теме:

По поводу вариантов решения (воспоминания) - была практика в организации, у которой ВЦ был в полуподвале Политехнического музея. Все ночное время было наше, а напротив был "Зеленый глаз" - ночная столовая для таксистов, так что даже с едой проблем не было. Одна из задач была в файле ИНПАДОК (кажется так он назывался, с информацией о патентах) найти патент по уникальному коду. Стандартное решение - работать с индексно-последовательным файлом на PL/I. Не стандартное - разместить файл на разделенных цилиндрах, создать оглавление (дорожка, ключ начальный, ключ конечный при обновление файла), грузить оглавление целиком в ОП, грузить найденную в нем дорожку целиком в ОП, искать в ней ... . Строк кода в таком варианте было на порядок больше (Ассемблер, однако), но работал он на порядок быстрее, что при обновлении файла раз в неделю было выгодно. И сколько подобно рода дилемм у Вам будет?

1
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 13:06  [ТС]
Цитата Сообщение от ltv_1953 Посмотреть сообщение
И сколько подобно рода дилемм у Вам будет?
Дилеммы мне как раз и нужны. Это и есть программирование. От нормального программирования, а не от формошлёпства, развивается мышление и утончается ум.
Цитата Сообщение от voral Посмотреть сообщение
то вам потребуется написать только один класс
Да ладно? А как быть со всеми текстовыми запросами с эхотагами на подмножестве языка SQL, специфичном для sqlite?
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 13:21
Цитата Сообщение от TrueTyper Посмотреть сообщение
Да ладно? А как быть со всеми текстовыми запросами с эхотагами на подмножестве языка SQL, специфичном для sqlite?
Легко. Если упрощено. Все специфичное решается именно внутри этого класса. Этот класс предоставляет интерфейс (публичные методы) который не зависит от реализации конкретного диалекта SQL, и вообще SQL. Весь ваш код обращается к нему ни чего не зная о таких тонкостях. И просто получает нужный результат выполнения. Т.е. тот код который например просит запомнить данные, или получить выборку, он может (и, в идеале, должен) вообще не знать о том как это все хранится.

Добавлено через 7 минут
Вашу боязнь о том что sqllite пропадет, можно и на ваше решение на файлах распространить (а вдруг его станет не хватать или сопровождение станет безумнодорогим для проекта)? Да и скорее вы вырастите из возможностей sqllite чем он пропадет

Изучите, если вам это все интересно, вопросы архитектур приложений. Это книга "Чистая архитектура", шаблоны GRASP, DRY и т.д и т.п. (там как начнете вникать в эту тематику много нового будет )
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 13:29  [ТС]
Для меня там нового ничего не будет.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 14:21
Цитата Сообщение от TrueTyper Посмотреть сообщение
Для меня там нового ничего не будет.
Если бы это было так, то у вас не возникало некоторых вопросов из этой темы
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 16:49  [ТС]
voral, ты советуешь людям говно мамонта. Придумай что-то оригинальное, а потом продавай. Этой макулатуре место в детской библиотеке. В реальном мире работает только процедурное программирование, надёжное и тестируемое, как автомат Калашникова.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 16:58
Цитата Сообщение от TrueTyper Посмотреть сообщение
В реальном мире работает только процедурное программирование, надёжное и тестируемое, как автомат Калашникова.
1 Между тем вовсе не обязательно про ООП говорить. Все те же самые принципы можно применять и с процедурным.
2 Это литература достойная. Если вы ее не понимаете, это минус только вам.

Добавлено через 5 минут
Цитата Сообщение от TrueTyper Посмотреть сообщение
надёжное и тестируемое, как автомат Калашникова.
Главное что б не выглядеть как обезьяна с гранатой хоть с ООП хоть без оной

Тестируется все. Правда надо учиться и понимать книги, которые читаешь... Если мозг есть то можно понять, что все о чем говориться в книгах про архитектуру с примерами на ООП, не означает, что это только про ООП. Все спокойно применяется.

Так что учитесь, набирайтесь опыта... и все у вас однажды получится. когда наберетесь опыта в том самом "реальном мире".
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 16:58  [ТС]
voral, и что же в ней достойного, кроме переписывания из других книг XX столетия?
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 17:01
Цитата Сообщение от TrueTyper Посмотреть сообщение
voral, и что же в ней достойного, кроме переписывания из других книг XX столетия?
Хорошо, можете почитать те из которых "переписано". Как ни крути, но вы не понимаете то о чем там написано. Как вы эту информацию добудете дело десятое. Дело не в конкретной книге, а в знаниях которые она пытается донести.
0
22.04.2023, 17:01  [ТС]

Не по теме:

voral, до чего ты докатился, что вместо политкорректной полемики ведёшь скрытую войну против оппонента, занижая ему баллы, чем он тебе ответить не может. Слабак.

0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 17:02
В любом случае: если вы замахнетесь на написание своей СУБД "на файлах" без понимания вопросов архитектуры вы просто потратите время. Это и будет ваш "подводный камень". (ну или "один из")
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 17:03  [ТС]
voral, так перечисли эти знания, если они там есть, а мы поучимся, если это - что-то вразумительное.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 17:04
Цитата Сообщение от TrueTyper Посмотреть сообщение
voral, до чего ты докатился, что вместо политкорректной полемики ведёшь скрытую войну против оппонента, занижая ему баллы, чем он тебе ответить не может. Слабак.
Для того это здесь и есть. Ты явно не владея знаниями назвал книгу говном, при этом книгу признанную теми кто в профессии. Так что это оценка твои действиям. Это не "спора ради".
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 17:05  [ТС]
voral, мне нужна вся субд, а лишь несколько функций, и я не пишу об ограничениях во времени нигде, благо менеджера и маркетолога надо мной нет.

Добавлено через 1 минуту
voral, я назвал её не так, а старьём. Переводи правильно.
0
3061 / 1463 / 265
Регистрация: 16.03.2008
Сообщений: 6,510
Записей в блоге: 2
22.04.2023, 17:05
Цитата Сообщение от TrueTyper Посмотреть сообщение
voral, так перечисли эти знания, если они там есть, а мы поучимся, если это - что-то вразумительное
Для чего мне это? Чтоб доказать какому то холиварщику что то? Да нафиг... ковыряйся как тебе нравится. Я дал совет, можешь не пользоваться. А я "метать икру перед свиньями" не собираюсь
0
-8 / 12 / 0
Регистрация: 15.02.2023
Сообщений: 421
22.04.2023, 17:07  [ТС]
voral, ну вот и слился, а мог бы доказать детям, что у тебя есть знания.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.04.2023, 17:07

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
60
Ответ Создать тему
Новые блоги и статьи
Сезонность и суточность закисления почв
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