springMVC使用与生成序列号
springMVC使用与生成序列号
我是以springMVC的方式提供序列号
代码可以直接在项目中用
第一步:controller类
@Autowired
private PkGenerator pkGenerator;
private static final String SEQ_PRIFIX = "DF";
private static final String SEQ_PRIFIX1 = "DM"; private static final String SEQ_NAME = "PAYMENT";
protected String genPk(string type) { if (type == "type1" || type == "type2") {
return pkGenerator.genPk(SEQ_NAME, SEQ_DF_PRIFIX + preReleaseFlag);
} else {
return pkGenerator.genPk(SEQ_NAME, SEQ_PRIFIX1 + preReleaseFlag);
}
}
第二步:PkGenerator类
package com.utils; import java.util.Date; import javax.annotation.Resource; import org.apache.commons.lang3.time.DateFormatUtils;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional; /**
* 序列生成
*
*
*/
public class PkGenerator { static final String SEQ_DATA_FORMAT = "yyyyMMdd"; @Resource(name = "accountMapper")
private Mapper<?> mapper; /**
* 生成序列
*
* @param seqName 序列名称
* @param prefix 前缀
* @return
*/
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public String genPk(String seqName, String prefix) {
return this.genPk(seqName, prefix, 4);
} /**
* 生成序列,长度超过设置长度不会跑出异常
*
* @param seqName 序列名称
* @param prefix 前缀
* @return
*/
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public String genPk(String seqName, String prefix, int length) { StringBuilder sb = new StringBuilder(prefix); int seq = 0;
seq = mapper.selectSeq(seqName, 1); String seqstr = getFixedLengthString(String.valueOf(seq), length);
sb.append(DateFormatUtils.format(new Date(), SEQ_DATA_FORMAT)).append(seqstr); return sb.toString().toUpperCase();
} /**
* 生成序列,该序列号不会清零处理,只会进行历史累加</br>
* 长度超过设置长度抛出异常
*
* @param seqName String 序列名称
* @param length int 固定长度
*
* @return
*/
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public String genPk2(String seqName, int length) {
StringBuilder sb = new StringBuilder(); int seq = 0;
seq = mapper.getSeqNum(seqName, 1); String seqstr = getFixedLengthString(String.valueOf(seq), length); if (seqstr.length() > length)
throw new IllegalArgumentException("序列号长度超过长度限制。"); sb.append(seqstr); return seqstr;
} /**
* 生成int类型序列
*
* @param seqName 序列名称
* @return
*/
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public int getSeqNum(String seqName) {
return this.getSeqNum(seqName, 1);
} /**
* 生成int类型序列
*
* @param seqName 序列名称
* @return
*/
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public int getSeqNum(String seqName, int length) {
return mapper.getSeqNum(seqName, length);
} /**
* 获取固定长度字符串,不足0补,长度超过直接返回
*/
public String getFixedLengthString(String raw, int length) {
if (raw == null)
throw new MandoErrorMessageException("raw data is null"); int size = raw.length(); if (size >= length)
return raw; int fillSize = length - size; return new StringBuilder().append(getLengthZero(fillSize)).append(raw).toString();
} }
第三步:一个Mapper类
@Select("call nextval(#{name},#{length})")
int selectSeq(@Param("name") String name, @Param("length") int length); @Select("call nextval_all(#{name},#{length})")
int getSeqNum(@Param("name") String name, @Param("length") int length);
第四部:PkGenerator 加到service.xml中
<bean class="com.zhonglian.jinjumng.utils.PkGenerator" />
就这样简单,成功的在一个项目中调用这个序列了。
代码可以直接上测试。
偶遇晨光原创
2016-02-29
springMVC使用与生成序列号的更多相关文章
- 利用ir.sequence自动生成序列号
利用ir.sequence自动生成序列号 什么是序列号 可以这么理解,我有一个产品序号,编码的前缀是SOP,后缀是0001~9999的序号,没生成一个产品就自动流水加一,序列号不会重复,odoo中的i ...
- SELECT (@i :=@i + 1)生成序列号
转载自https://blog.csdn.net/qq_27922171/article/details/86477544 同类别自动生成序列号:https://bbs.csdn.net/topics ...
- 160920、springmvc上传图片不生成临时文件
springMVC上传图片时候小于10k不会再临时目录里面生成临时文件,需要增加一个配置 <property name="maxInMemorySize" value=&qu ...
- SQL Server 怎样生成序列号(虚拟数字辅助表)
</pre><pre name="code" class="sql">--生成一个"序列" 或者说生成一个" ...
- SpringMVC将url生成二维码图片直接展示在页面上
利用google的开源包zxing生成二维码 第一步:maven项目的zxing依赖 <!-- google zxing 生成二维码 --> <dependency> < ...
- Idea为类生成序列号(十一)
新建一个测试的实体类Gradle,实现java.io.Serializable接口,选择类名,按Alt+Enter键,出现的提示框中没有生成serialVersionUID的提示,这个需要设置之后才会 ...
- 使用Redis的INCR、Hsetnx、Hincrby的命令生成序列号
Redis INCR命令 用于由一个递增key的整数值.如果该key不存在,它被设置为0执行操作之前.如果key包含了错误类型的值或包含不能被表示为整数,字符串,则返回错误.该操作被限制为64位带符号 ...
- springmvc使用swagger生成rest api文档
pom.xml <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-s ...
- mysql查询结果自动生成序列号
随机推荐
- juery常用
1input解除焦点时触发操作 同时给另一个元素赋值 $(document).ready(function(){ $("input[name='url']").change(fun ...
- Hibernate原生SQL查询多表关联,SQL语句要注意的问题
Hibernate原生SQL查询多表关联,SQL语句要注意的问题 @for&ever 2009-9-4 系统环境: MySQL5.1 Hibernate3.3 有如下的假定: 实体类 Ques ...
- java 代码的细节优化
前言 代码优化,一个很重要的课题.可能有些人觉得没用,一些细小的地方有什么好修改的,改与不改对于代码的运行效率有什么影响呢?这个问题我是这么考虑 的,就像大海里面的鲸鱼一样,它吃一条小虾米有用吗?没用 ...
- 解决R速度太慢问题
R的速度慢一直被人诟病,最近做一个比较大的dataset的分析,跑得实在太慢,发现症结是R的data frame的index太慢: 以下为测试: gene_list = 1:100000 eQTL_m ...
- git新建仓库
克隆地址 git clone https://git.oschina.net/dy09/dy_shop.git 在克隆下来的文件夹里面进行下面的操作1.git add -A 2.git commit ...
- 第一篇T语言实例开发(版本5.3),带错误检测的加减乘除运算器
带错误检测的加减乘除运算器 表达式 TC综合开发工具里的表达式大体分为:计算表达式.条件表达式 计算表达式: 它一般是用在赋值过程中,或者是和条件表达式混合使用这样的表达式里只有数字运算符(如:+.- ...
- 《C与指针》第六章练习
本章问题 1.如果一个值的类型无法简单的通过观察它的位模式来判断,那么机器是如何知道应该怎样对这个值进行操纵的? answer:The machine doesn't make this determ ...
- codeforces 381 D Alyona and a tree(倍增)(前缀数组)
Alyona and a tree time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- cdr创建样式与样式集的方法
样式是一组定义对象属性的格式化属性,如轮廓或填充.例如,要定义轮廓样式,您可以指定轮廓宽度.颜色和线条类型等属性.要定义字符样式,您可以指定字体类型.字体样式和大小.文本颜色和背景色.字符位置.大写等 ...
- [转]SQLServer2008日志文件无法收缩处理方法
问题描述 发现有的数据库日志文件太大,无论如何收缩执行几次SQL语句都不行.事务日志达30+G,而且使用常规的截断.收缩方法均无法减小日志物理文件的尺寸,经过一番寻找,终于找到了解决方法. 查 ...