SHOW:
|
|
- or go back to the newest paste.
1 | CREATE TABLE _sequence | |
2 | ( | |
3 | seq_name VARCHAR(50) NOT NULL PRIMARY KEY, | |
4 | seq_group VARCHAR(10) NOT NULL, | |
5 | seq_val INT UNSIGNED NOT NULL | |
6 | ); | |
7 | ||
8 | delimiter // | |
9 | DROP FUNCTION IF EXISTS getNextCustomSeq// | |
10 | CREATE FUNCTION getNextCustomSeq | |
11 | ( | |
12 | sSeqName VARCHAR(50), | |
13 | sSeqGroup VARCHAR(10) | |
14 | ) RETURNS VARCHAR(20) | |
15 | BEGIN | |
16 | DECLARE nLast_val INT; | |
17 | SET nLast_val = (SELECT seq_val | |
18 | FROM _sequence | |
19 | WHERE seq_name = sSeqName | |
20 | AND seq_group = sSeqGroup); | |
21 | IF nLast_val IS NULL THEN | |
22 | SET nLast_val = 1; | |
23 | INSERT INTO _sequence (seq_name,seq_group,seq_val) | |
24 | VALUES (sSeqName,sSeqGroup,nLast_Val); | |
25 | ELSE | |
26 | SET nLast_val = nLast_val + 1; | |
27 | UPDATE _sequence SET seq_val = nLast_val | |
28 | WHERE seq_name = sSeqName AND seq_group = sSeqGroup; | |
29 | END IF; | |
30 | SET @ret = (SELECT concat(sSeqGroup,'-',nLast_val)); | |
31 | RETURN @ret; | |
32 | END// | |
33 | delimiter ; | |
34 | ||
35 | ||
36 | DROP TRIGGER IF EXISTS tr_custom_autonums// | |
37 | CREATE TRIGGER tr_custom_autonums BEFORE INSERT ON tb_pegawai | |
38 | FOR each ROW | |
39 | BEGIN | |
40 | - | SET NEW.id_pegawai = getNextCustomSeq("PG","1"); |
40 | + | SET NEW.id_pegawai = getNextCustomSeq("id_pegawai","PG"); |
41 | END// | |
42 | delimiter ; |