oracle?指定類型和指定位數(shù)創(chuàng)建序列號的代碼詳解
發(fā)布日期:2022-07-15 19:06 | 文章來源:站長之家
一、腳本部分
1. 表結(jié)構(gòu)
有注釋
-- Create table create table LDMAXNO ( NOTYPE VARCHAR2(17) not null, NOLIMIT VARCHAR2(12) not null, MAXNO INTEGER not null ); -- Add comments to the table comment on table LDMAXNO is '產(chǎn)生最大的流水號,所有的號碼從1開始'; -- Add comments to the columns comment on column LDMAXNO.NOTYPE is '含義描述:1、號碼類型'; comment on column LDMAXNO.NOLIMIT is '含義描述:1、號碼限制條件'; comment on column LDMAXNO.MAXNO is '含義描述:1、當(dāng)前最大值'; -- Create/Recreate primary, unique and foreign key constraints alter table LDMAXNO add constraint PK_LDMAXNO primary key (NOTYPE, NOLIMIT);
2. 函數(shù)
create or replace function CreateMaxNos(cNoType in ldmaxno.notype%type,
cNoLimit in ldmaxno.nolimit%type)
return integer is
pragma autonomous_transaction;
tMaxNo integer := 0; --初始化賦值等于0,定義返回變量
begin
--最大數(shù)加1
update LDMaxNo
set MaxNo = MaxNo + 1
where NoType = cNoType
and NoLimit = cNoLimit
Returning MaxNo Into tMaxNo; --取出最大數(shù)
If (Sql%Notfound) then
--第一次向數(shù)據(jù)庫中插入最大數(shù)為 1 的記錄
Insert Into LDMaxNo
(NOTYPE, NOLIMIT, MAXNO)
values
(cNoType, cNoLimit, 1);
tMaxNo := 1;
End If;
commit;
return(tMaxNo); --返回結(jié)果
end CreateMaxNos;
/二、代碼部分
2.1. xml
DullMapper.xml
<?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="com.gblfy.business.mapper.DullMapper">
<select id="getMaxNo" resultType="java.lang.String">
select createmaxno(#{cNoType},#{cNoLength}) from dual
</select>
</mapper>2.2. 接口
DullMapper.java
package com.gblfy.business.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param;
public interface DullMapper extends BaseMapper {
/**
* 功能:產(chǎn)生指定長度的流水號,一個(gè)號碼類型一個(gè)流水
* @param cNoType 流水號的類型
* @param cNoLength 流水號的長度
* @return 返回產(chǎn)生的流水號碼
*/
String getMaxNo(@Param("cNoType") String cNoType, @Param("cNoLength") int cNoLength);
}
2.3. api接口
package com.gblfy.business.service;
public interface SysMaxNoService {
/**
* 功能:產(chǎn)生指定長度的流水號,一個(gè)號碼類型一個(gè)流水
*
* @param cNoType 流水號的類型
* @param cNoLength 流水號的長度
* @return 返回產(chǎn)生的流水號碼
*/
String createMaxNo(String cNoType, int cNoLength);
}2.4. api實(shí)例
package com.gblfy.business.service.impl;
import com.gblfy.business.mapper.DullMapper;
import com.gblfy.business.service.SysMaxNoService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.math.BigInteger;
@Service
public class SysMaxNoServiceImpl implements SysMaxNoService {
private final static Logger logger = LoggerFactory.getLogger(SysMaxNoServiceImpl.class);
@Resource
private DullMapper dullMapper;
/**
* 功能:產(chǎn)生指定長度的流水號,一個(gè)號碼類型一個(gè)流水
*
* @param cNoType 流水號的類型
* @param cNoLength 流水號的長度
* @return 返回產(chǎn)生的流水號碼
*/
@Override
public String createMaxNo(String cNoType, int cNoLength) {
if ((cNoType == null) || (cNoType.trim().length() <= 0) ||
(cNoLength <= 0)) {
logger.info("NoType長度錯(cuò)誤 {} NoLength錯(cuò)誤", cNoType, cNoLength);
return null;
}
cNoType = cNoType.toUpperCase();
String tReturn = "";
String cNoLimit = "SN";
BigInteger tMaxNo = new BigInteger("0");
tReturn = cNoLimit;
try {
String result = dullMapper.getMaxNo(cNoType, cNoLength);
tMaxNo = new BigInteger(result);
} catch (Exception e) {
e.printStackTrace();
logger.info("生成流水號出現(xiàn)異常,請核實(shí)!");
}
String tStr = tMaxNo.toString();
//將生成的流水號進(jìn)行加工處理
tStr = LCh(tStr, "0", cNoLength);
tReturn = tStr.trim();
return tReturn;
}
/**
* 將生成的流水號進(jìn)行加工處理
* <p>
* 1.判斷是否滿足指定長度,如果不滿足前面用0來補(bǔ)位
* 2.將生成的流水號進(jìn)行去空格處理
* 3.將最終的流水號進(jìn)行字符串拼接
* </P>
*
* @param sourString
* @param cChar
* @param cLen
* @return
*/
private String LCh(String sourString, String cChar, int cLen) {
int tLen = sourString.length();
int i, iMax;
String tReturn = "";
if (tLen >= cLen) {
return sourString;
}
//1.判斷是否滿足指定長度,如果不滿足前面用0來補(bǔ)位
iMax = cLen - tLen;
for (i = 0; i < iMax; i++) {
tReturn += cChar;
}
//2.將生成的流水號進(jìn)行去空格處理
//3.將最終的流水號進(jìn)行字符串拼接
tReturn = tReturn.trim() + sourString.trim();
return tReturn;
}
}
2.5. 控制層
package com.gblfy.business.controller;
import com.gblfy.business.service.SysMaxNoService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
/**
* 生成指定類型+位數(shù)的流水號
*
* @Author gblfy
* @Date 2022-05-16 20:13
**/
@RestController
public class SysMaxNoController {
@Autowired
private SysMaxNoService maxNoService;
/**
* 生成指定類型+位數(shù)的流水號
*
* @param cNoType
* @param cNoLength
* @return
*/
@GetMapping("/generate/serial/number")
public String generateSerialNumber(@RequestParam(name = "cNoType", required = false, defaultValue = "cNoType") String cNoType,
@RequestParam int cNoLength) {
return maxNoService.createMaxNo(cNoType, cNoLength);
}
}
三、測試
3.1. 效果圖


到此這篇關(guān)于oracle指定類型和指定位數(shù)創(chuàng)建序列號的文章就介紹到這了,更多相關(guān)oracle創(chuàng)建序列號內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
相關(guān)文章
關(guān)注官方微信