如何从PHP中的F-00001开始生成唯一的tag_id

时间:2018-11-03 04:13:44

标签: php mysql php-7

当使用php和mysql将日期插入项目表时,如何从F-00001开始生成唯一的tag_id。

这是我的桌子。使用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 :(得分:2)

正如@mickmackusa指出的那样,您无需在数据库中包含此字段,因为您可以根据自动递增的id值自动生成该字段。有很多方法可以做到这一点。

使用generated column(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'))
)

使用view

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

使用str_pad在PHP中生成:

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