Я пытался реализовать первичный индекс для файла данных, который имеет запись переменной длины, указанную индикатором длины и разделителем полей, например. lengthindicatorid|name|gpa 14001|raghad|3.5 и т. д.
Основной индекс принимает идентификатор и смещение байтов записи, поэтому при поиске определенных запись с использованием идентификатора, основной индекс возьмет смещение в байтах рядом с идентификатором и попытается получить его с помощью файла данных. Как я могу это сделать?
Я реализовал код, который добавляет врача и рассчитывает положение этой записи, чтобы я брал ее с идентификатором в индексном файле (смещение), чтобы помочь мне получить записать, когда я захочу его найти. Логика правильная, и такие операции, как поиск, работают хорошо. Он извлекает целевую запись, но смещение вычисляется неправильно для каждой записи. Несмотря на то, что он рассчитан неправильно, запись извлекается правильно!
Это код addDoctor, имеющий логику позиции:
void HealthcareManagementSystem::addDoctor(const string& doctorID, const string& name, const string& address) {
// Check if the doctor already exists using binary search on primary index
if (binarySearch(doctorPrimaryIndex, doctorID) != -1) {
cout
Подробнее здесь: https://stackoverflow.com/questions/792 ... ementation
Первичный индекс реализации записи переменной длины ⇐ C++
Программы на C++. Форум разработчиков
-
Anonymous
1733018474
Anonymous
Я пытался реализовать первичный индекс для файла данных, который имеет запись переменной длины, указанную индикатором длины и разделителем полей, например. lengthindicatorid|name|gpa 14001|raghad|3.5 и т. д.
Основной индекс принимает идентификатор и смещение байтов записи, поэтому при поиске определенных запись с использованием идентификатора, основной индекс возьмет смещение в байтах рядом с идентификатором и попытается получить его с помощью файла данных. Как я могу это сделать?
Я реализовал код, который добавляет врача и рассчитывает положение этой записи, чтобы я брал ее с идентификатором в индексном файле (смещение), чтобы помочь мне получить записать, когда я захочу его найти. Логика правильная, и такие операции, как поиск, работают хорошо. Он извлекает целевую запись, но смещение вычисляется неправильно для каждой записи. Несмотря на то, что он рассчитан неправильно, запись извлекается правильно!
Это код addDoctor, имеющий логику позиции:
void HealthcareManagementSystem::addDoctor(const string& doctorID, const string& name, const string& address) {
// Check if the doctor already exists using binary search on primary index
if (binarySearch(doctorPrimaryIndex, doctorID) != -1) {
cout
Подробнее здесь: [url]https://stackoverflow.com/questions/79237798/primary-index-on-variable-length-record-implementation[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия