私はこのようなテーブルを持っています
table
id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name CHAR(30) NOT NULL,
... などのように id フィールドをインクリメントしたいのです'LHPL001','LHPL002','LHPL003'
が、そのためにはどうすればよいですか? 可能な方法を教えてください。
私はこのようなテーブルを持っています
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 | 名前 | ------------------ | | LHPL001 | ジョン | | | LHPL002 | マーク |
これがSQLFiddleのデモです
通常の数値 auto_increment ID でテーブルを作成しますが、 で定義するか、 をZEROFILL
使用LPAD
して選択時にゼロを追加します。次にCONCAT
、意図した動作を取得するための値。例 #1:
create table so (
id int(3) unsigned zerofill not null auto_increment primary key,
name varchar(30) not null
);
insert into so set name = 'John';
insert into so set name = 'Mark';
select concat('LHPL', id) as id, name from so;
+---------+------+
| id | name |
+---------+------+
| LHPL001 | John |
| LHPL002 | Mark |
+---------+------+
例 #2:
create table so (
id int unsigned not null auto_increment primary key,
name varchar(30) not null
);
insert into so set name = 'John';
insert into so set name = 'Mark';
select concat('LHPL', LPAD(id, 3, 0)) as id, name from so;
+---------+------+
| id | name |
+---------+------+
| LHPL001 | John |
| LHPL002 | Mark |
+---------+------+