parent
0e3fd7c23b
commit
d2acc24567
@ -0,0 +1,36 @@
|
||||
package cokr.xit.ens.modules.common.ctgy.sys.mng.service;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import javax.transaction.Transactional;
|
||||
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import cokr.xit.ens.modules.common.ctgy.sys.mng.mapper.IKeySequenceMapper;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
|
||||
@Service
|
||||
@RequiredArgsConstructor
|
||||
public class KeySequenceService {
|
||||
|
||||
private final IKeySequenceMapper mapper;
|
||||
|
||||
/**
|
||||
* 키 시퀀스 조회
|
||||
* @param seqName 키 시퀀스 이름
|
||||
* @return Long
|
||||
*/
|
||||
@Transactional
|
||||
public Long getKeySequence(String seqName) {
|
||||
Long nextSeq = mapper.selectKeySequence(seqName);
|
||||
if(nextSeq == null) {
|
||||
nextSeq = 1L;
|
||||
}
|
||||
Map<String, Object> map = new HashMap<>();
|
||||
map.put("seqName", seqName);
|
||||
map.put("nextVal", nextSeq);
|
||||
mapper.saveKeySequence(map);
|
||||
return nextSeq;
|
||||
}
|
||||
}
|
@ -0,0 +1,27 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="cokr.xit.ens.modules.common.ctgy.sys.mng.mapper.IKeySequenceMapper">
|
||||
|
||||
<select id="selectKeySequence" parameterType="string" resultType="long">
|
||||
/** iup-keyseq-mapper|selectKeySequence-key sequence 조회|julim */
|
||||
SELECT next_val + 1
|
||||
FROM ens_seq_generator
|
||||
WHERE seq_name = #{seqName}
|
||||
FOR UPDATE
|
||||
</select>
|
||||
|
||||
<insert id="saveKeySequence" parameterType="map">
|
||||
/** iup-keyseq-mapper|saveKeySequence-key sequence 저장|julim */
|
||||
MERGE
|
||||
INTO ens_seq_generator tgt
|
||||
USING (SELECT #{seqName} AS seq_name, #{nextVal} AS next_val FROM dual) src
|
||||
ON (tgt.seq_name = src.seq_name)
|
||||
WHEN MATCHED THEN
|
||||
UPDATE SET tgt.next_val = src.next_val
|
||||
WHEN NOT MATCHED THEN
|
||||
INSERT (seq_name, next_val)
|
||||
VALUES (src.seq_name, src.next_val)
|
||||
</insert>
|
||||
|
||||
</mapper>
|
Loading…
Reference in New Issue