R
Rus6lan16 мая 2017 г. 8:38

AUTOINCREMENT in Sqlite

Такая проблема (а может и не проблема), У меня стоит автоинкрементация поля id в таблице. Я то удаляю, то добавлю там записи( проверяю работу приложения). А id все растет. Мне кажется должно выглядеть как-то аккуратнее. А еще вопрос. У меня есть таблица студенты. Есть таблица преподаватели, мне надо, чтобы при выборе строчки в tableview(с преподавателями), в другом tableview отображались студенты именно это преподавателя. Я решил, что я добавлю строчку id_teacher в таблицу студентов, и при выбирании строчки в tableview(преподаватели) буду делать select * from students where id_teacher = и id выбранной строчки. Как вы считаете это нормальное решение?

Screenshot_2.png
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

4
R
  • 16 мая 2017 г. 8:39

Вот скрин программы.

    Evgenii Legotckoi
    • 16 мая 2017 г. 10:20

    Что касается автоикрементации, то не обращайте на это внимание - это обычное поведение баз данных. ID должен быть уникальным для записей, а автоматическая инкрементация - это как раз тот механизм, который переносит проблему подбора ID на сторону базы данных. Это не должно выглядеть аккуратнее, это должно работать как следует и это работает как следует.

    Можете конечно загрузиться поиском свободного ID и вставки именно в свободный ID записи, чтобы было красиво, только в вашей программе я не вижу смысла в этом. Только код усложните.

    Что касается вашего решения по подбору учеников по преподавателю, то это верное решение, только делайте id_teacher как FOREIGN KEY на таблицу учителей - это будет правильнее, а не просто хранить id как целочисленное значение. Тогда больше возможностей SQL будет доступно.

      R
      • 16 мая 2017 г. 15:37

      А удобнее использовать QSqlRelationalTableModel? Я использую просто QSqlTableModel.

        Evgenii Legotckoi
        • 17 мая 2017 г. 0:14
        QSqlRelationTableModel позволит дёрнуть колонки из других таблиц, на которые есть внешние ключи. Если же вы выводите только таблицу с учениками, то без разницы, я бы оставил и QSqlTableModel .

          Комментарии

          Только авторизованные пользователи могут публиковать комментарии.
          Пожалуйста, авторизуйтесь или зарегистрируйтесь
          AD

          C++ - Тест 004. Указатели, Массивы и Циклы

          • Результат:50баллов,
          • Очки рейтинга-4
          m
          • molni99
          • 26 октября 2024 г. 8:37

          C++ - Тест 004. Указатели, Массивы и Циклы

          • Результат:80баллов,
          • Очки рейтинга4
          m
          • molni99
          • 26 октября 2024 г. 8:29

          C++ - Тест 004. Указатели, Массивы и Циклы

          • Результат:20баллов,
          • Очки рейтинга-10
          Последние комментарии
          i
          innorwall12 ноября 2024 г. 5:12
          Django - Урок 055. Как написать функционал auto populate field Freckles because of several brand names retin a, atralin buy generic priligy
          i
          innorwall12 ноября 2024 г. 1:23
          QML - Урок 035. Использование перечислений в QML без C++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
          i
          innorwall11 ноября 2024 г. 22:50
          Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
          i
          innorwall11 ноября 2024 г. 21:19
          Алгоритм сортировки кучей The role of raloxifene in preventing breast cancer priligy precio
          i
          innorwall11 ноября 2024 г. 20:55
          PyQt5 - Урок 006. Работа с QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
          Сейчас обсуждают на форуме
          i
          innorwall12 ноября 2024 г. 3:56
          добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
          i
          innorwall11 ноября 2024 г. 17:55
          Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
          9
          9Anonim25 октября 2024 г. 16:10
          Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
          ИМ
          Игорь Максимов3 октября 2024 г. 11:05
          Реализация навигации по разделам Спасибо Евгений!

          Следите за нами в социальных сетях