Loopback4 MySQL Auto-Increment ID

Я только что установил Loopback4 (на основе TS), и я пытаюсь поиграть с ним, так как кажется очень простым создать API с его помощью. Мой вопрос довольно простой (но я не знаю ответа). Как я могу увеличить идентификатор моей модели?

Допустим, у меня это есть в моей модели (созданной с помощью lb4 model) ->

export class Post extends Entity {
  @property({
    type: 'number',
    id: true,
    required: false,
  })
  Id: number;

Первое сообщение (без добавления ID) создает его с Id = 0. Следующего сообщения нет, так как Id не увеличивается автоматически.

Любой совет о том, как это сделать? Я использую MySQL, как указано в моем заголовке, и LB4.

Обновлено: Или даже лучше, есть ли способ изменить способ создания таблиц Loopback4 (loopback-next)? Есть одна команда, которую нужно будет запустить после создания таблиц БД, что-то вроде ALTER TABLE post CHANGE Id Id INT(11) NOT NULL AUTO_INCREMENT;

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

А как насчет использования AUTO_INCREMENT в MySQL? Нравится: id INT NOT NULL AUTO_INCREMENT?

Vüsal 24.12.2018 17:30

Это может сработать, однако я не слишком опытен в MySQL, и я не уверен, как это сделать, и есть ли какие-либо недостатки в этом. Поскольку создание БД и строк выполняется на 100% LoopBack4, я думаю, что было бы лучше увеличить его, а не MySQL.

Dante R. 24.12.2018 17:35
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
2
1 429
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Исправлено благодаря github. Судя по всему, он очень похож на LB3 (которым я не пользовался).

  @property({
    type: 'number',
    id: true,
    generated: true,
  })
  Id: number;

Добавление generated: true включает автоинкремент в mysql.

Я создал таблицу, и свойство id изначально не имело сгенерированного свойства, и миграция, по-видимому, не проверяет это на postgresql, действительно удаляла таблицу, повторно запускала миграцию, после этого все работало нормально.

hazimdikenli 16.05.2019 14:20

Другие вопросы по теме