web-dev-qa-db-ja.com

MySQLテーブルの主キーをプレフィックスで自動インクリメントさせる方法

こんなテーブルがあります

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

'LHPL001','LHPL002','LHPL003'...などのように自分のidフィールドをインクリメントしたいのですが、そのために何をしなければなりませんか?考えられる方法を教えてください。

63
Vijay

あなたが本当にこれを必要とするならば、あなたは順序付けのための別々のテーブル(あなたが気にしないなら)と引き金の助けを借りてあなたの目的を達成することができます。

テーブル

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のデモです

109
peterm

通常の数値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 |
+---------+------+
15
Fluffy

私はそれが遅れていることを知っています、しかし、私はちょうど私がこれのためにしたことについて共有したいです。他のテーブルやトリガを追加することはできませんので、挿入時に単一のクエリで生成する必要があります。あなたの場合は、このクエリを試すことができます。

CREATE TABLE YOURTABLE(
IDNUMBER VARCHAR(7) NOT NULL PRIMARY KEY,
ENAME VARCHAR(30) not null
);

選択を実行してこの選択クエリを使用し、パラメータ@IDNUMBERに保存します。

(SELECT IFNULL
     (CONCAT('LHPL',LPAD(
       (SUBSTRING_INDEX
        (MAX(`IDNUMBER`), 'LHPL',-1) + 1), 5, '0')), 'LHPL001')
    AS 'IDNUMBER' FROM YOURTABLE ORDER BY `IDNUMBER` ASC)

そして、Insert queryは以下のようになります。

INSERT INTO YOURTABLE(IDNUMBER, ENAME) VALUES 
(@IDNUMBER, 'EMPLOYEE NAME');

結果は他の答えと同じになりますが、違いは別のテーブルやトリガを作成する必要がないということです。私と同じ事件を抱えている人を手助けできることを願っています。

3
yhAm