БД содержит информацию об учениках школы : фамилия класс балл за тест балл за практическое задание общееиколичество балов . какова типа должно быть поле общее количество ббалов?
Ответы на вопрос
Кратко: числовое, лучше вычисляемое (не хранить отдельно).
Развернуто:
-
Тип данных
-
Если баллы всегда целые →
INTEGER/INT. -
Если возможны дробные (0,5; 4,75 и т.п.) → фиксированная точность:
DECIMAL(p,s)(напр.,DECIMAL(5,2)), а неFLOAT, чтобы избежать ошибок округления.
-
Лучше не дублировать данные
общее_количество_баллов— это сумма «балл за тест» + «балл за практическое». Чтобы не хранить избыточность и не ловить рассинхронизацию, задайте его как вычисляемое поле (generated/virtual column) или рассчитывайте в запросе.
Примеры:
PostgreSQL (через вычисление в запросе):
MySQL (сгенерированная колонка):
-
Ограничения (желательно):
-
Проверки на неотрицательные значения и верхние границы:
(и при необходимости <= максимуму за каждый компонент).
Итого: выбирайте INT, если только целые; DECIMAL(p,s), если нужны дроби. Оптимально сделать «общее количество баллов» вычисляемым числовым полем, а не отдельным хранимым значением.
Похожие вопросы
Топ вопросов за вчера в категории Информатика
Последние заданные вопросы в категории Информатика
-
Математика
-
Литература
-
Алгебра
-
Русский язык
-
Геометрия
-
Английский язык
-
Химия
-
Физика
-
Биология
-
Другие предметы
-
История
-
Обществознание
-
Окружающий мир
-
География
-
Українська мова
-
Информатика
-
Українська література
-
Қазақ тiлi
-
Экономика
-
Музыка
-
Право
-
Беларуская мова
-
Французский язык
-
Немецкий язык
-
МХК
-
ОБЖ
-
Психология
-
Физкультура и спорт
-
Астрономия
-
Кыргыз тили
-
Оʻzbek tili

