1. ホーム
  2. mysql

[解決済み] MySQLテーブルの主キーを何らかの接頭辞で自動インクリメントする方法

2022-03-04 21:42:55

質問

このようなテーブルがあります。

table
id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name CHAR(30) NOT NULL,

id フィールドを次のようにインクリメントしたい。 'LHPL001','LHPL002','LHPL003' ... など。 そのためにはどうしたらよいのでしょうか?何か可能な方法があれば教えてください。

解決方法は?

もし、本当に必要なら、シーケンス用の別のテーブルとトリガーの助けを借りて目的を達成することができます。

テーブル

CREATE TABLE table1_seq
(
  id INT NOT NULL AUTO_INCREMENT PRIMARY KEY
);
CREATE TABLE table1
(
  id VARCHAR(7) NOT NULL PRIMARY KEY DEFAULT '0', name VARCHAR(30)
);

次にトリガー

DELIMITER $$
CREATE TRIGGER tg_table1_insert
BEFORE INSERT ON table1
FOR EACH ROW
BEGIN
  INSERT INTO table1_seq VALUES (NULL);
  SET NEW.id = CONCAT('LHPL', LPAD(LAST_INSERT_ID(), 3, '0'));
END$$
DELIMITER ;

そして、table1 に行を挿入するだけです。

INSERT INTO Table1 (name) 
VALUES ('Jhon'), ('Mark');

そして、あなたが持っているのは

| ID|NAME|(名前
------------------
| LHPL001|Jhon|(ジェイホン
| LHPL002|マーク

以下は SQLFiddle デモ