私はこのようなテーブルを持っています
table
id Varchar(45) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name CHAR(30) NOT NULL,
'LHPL001','LHPL002','LHPL003'
...などのようにidフィールドをインクリメントしたい。そのために何をする必要がありますか?可能な方法を教えてください。
回答:
これが本当に必要な場合は、シーケンス用の個別のテーブル(気にしない場合)とトリガーを使用して目標を達成できます。
テーブル
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_incrementIDを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 |
+---------+------+
私はそれが遅いことを知っていますが、私がこれのためにしたことについて共有したいと思います。別のテーブルやトリガーを追加することは許可されていないため、挿入時に1つのクエリで生成する必要があります。あなたの場合、このクエリを試してみてください。
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 INTO YOURTABLE(IDNUMBER, ENAME) VALUES
(@IDNUMBER, 'EMPLOYEE NAME');
結果は他の回答と同じになりますが、違いは、別のテーブルやトリガーを作成する必要がないことです。私と同じ事件を抱えている人を助けられることを願っています。
誰かがPostgreSQLで必要な場合、トリガーなしのPostgreSQLの例を次に示します。
CREATE SEQUENCE messages_seq;
CREATE TABLE IF NOT EXISTS messages (
id CHAR(20) NOT NULL DEFAULT ('message_' || nextval('messages_seq')),
name CHAR(30) NOT NULL,
);
ALTER SEQUENCE messages_seq OWNED BY messages.id;