Как сгенерировать уникальный старт tag_id из F-00001 в php - PullRequest
0 голосов
/ 03 ноября 2018

Как сгенерировать уникальный стартовый tag_id из F-00001 при вставке даты в таблицу элементов с помощью php и mysql.

Это мой мой стол. У меня есть три столбца в моей таблице базы данных с использованием MySQL.

CREATE TABLE item (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
Name VARCHAR(30) NOT NULL,
tag_id VARCHAR(8) NOT NULL
)

1 Ответ

0 голосов
/ 03 ноября 2018

Как указывает @mickmackusa, вам не нужно иметь это поле в вашей базе данных, поскольку вы можете автоматически сгенерировать его из значения id с автоинкрементом. Есть несколько способов сделать это.

Используйте сгенерированный столбец (MySQL 5.7 или более поздняя версия):

CREATE TABLE item (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
Name VARCHAR(30) NOT NULL,
tag_id VARCHAR(8) AS CONCAT('F-', LPAD(id, 5, '0'))
)

Использовать представление :

CREATE VIEW item_view AS 
SELECT *, CONCAT('F-', LPAD(id, 5, '0')) AS tag_id FROM item

Генерация в PHP с использованием str_pad:

// assume $row is an associative array of row of table
$tag_id = 'F-' . str_pad($row['id'], 5, '0', STR_PAD_LEFT);
...