ORA-02289: 序列不存在

在做申请的时候用到了DUAL虚拟表(申请单号的获取)
在oracle数据库中执行下面的代码创建一张虚拟表
ORA-02289: 序列不存在

create sequence SEQ_PIMSAPPLYNO
minvalue 1
maxvalue 999999999999999999999999999
start with 1
increment by 1;

执行下面的代码测试是否成功

SELECT SEQ_PIMSAPPLYNO.NEXTVAL as applyno FROM DUAL

成功之后在后台通过这个方法获取申请单号

public String getPimsApplyNO() {
	Map<String,Object> map = new HashMap<>();
	String sql = "SELECT SEQ_PIMSAPPLYNO.NEXTVAL as applyno FROM DUAL";
	map = jdbcTemplate.queryForMap(sql);
	return "SQ"+ DateUtil.getYear() + FormatNumberUtils.fixLength(8, Integer.parseInt(String.valueOf(map.get("applyno"))));
}

两个工具类DateUtil 和FormatNumberUtils


import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Locale;
import java.util.Random;
import java.util.TimeZone;
import java.util.regex.Pattern;

import org.apache.commons.lang.time.DateUtils;

public class DateUtil {

	/**
	 * 获取当前Date型日期
	 * 
	 * @return Date() 当前日期
	 */
	public static Date getNowDate() {
		return new Date();
	}

	/**
	 * 获取当前年份
	 * 
	 * @return 返回当前日期(yyyy)
	 */
	public static String getYear() {
		Calendar calendar = Calendar.getInstance();
		DateFormat dateFormat = new SimpleDateFormat("yyyy");
		dateFormat.setTimeZone(TimeZone.getTimeZone("GMT+8"));
		return dateFormat.format(calendar.getTime());
	}
	/**
	 * 获取当前日期
	 * 
	 * @return 返回当前日期(yyyyMMdd)
	 */
	public static String getDate() {
		Calendar calendar = Calendar.getInstance();
		DateFormat dateFormat = new SimpleDateFormat("yyyyMMdd");
		dateFormat.setTimeZone(TimeZone.getTimeZone("GMT+8"));
		return dateFormat.format(calendar.getTime());
	}
	
	/**
	 * 获取当前日期
	 * 
	 * @return 返回当前日期(yyyy-MM-dd)
	 */
	public static String getDate_long() {
		Calendar calendar = Calendar.getInstance();
		DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
		dateFormat.setTimeZone(TimeZone.getTimeZone("GMT+8"));
		return dateFormat.format(calendar.getTime());
	}

	/**
	 * 获取当前日期
	 * 
	 * @return 返回当前日期(yyyy-MM-dd HH:mm:ss)
	 */
	public static String getDateTime() {
		Calendar calendar = Calendar.getInstance();
		DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		dateFormat.setTimeZone(TimeZone.getTimeZone("GMT+8"));
		return dateFormat.format(calendar.getTime());
	}
	
	

	/**
	 * 按特定的日期格式获取当前字符串型日期
	 * 
	 * @param dateFormatType
	 *            String,日期格式<br>
	 *            几种日期格式和测试的结果<br>
	 *            "yyyy-MM-dd": 2012-08-02<br>
	 *            "yyyy-MM-dd hh:mm:ss": 2012-08-02 11:27:41<br>
	 *            "yyyy-MM-dd hh:mm:ss EE": 2012-08-02 11:27:41 星期四<br>
	 *            "yyyy年MM月dd日 hh:mm:ss EE": 2012年08月02日 11:27:41 星期四<br>
	 * @return String 当前字符串型日期
	 */
	public static String getNowDateFormat(String dateFormatType) {
		SimpleDateFormat simformat = new SimpleDateFormat(dateFormatType);
		return simformat.format(getNowDate());
	}

	/**
	 * 按特定的日期格式获取当前字符串型日期
	 * 
	 * @param date
	 *            指定的时间
	 * @param dateFormatType
	 *            String,日期格式<br>
	 *            几种日期格式和测试的结果<br>
	 *            "yyyy-MM-dd": 2012-08-02<br>
	 *            "yyyy-MM-dd hh:mm:ss": 2012-08-02 11:27:41<br>
	 *            "yyyy-MM-dd hh:mm:ss EE": 2012-08-02 11:27:41 星期四<br>
	 *            "yyyy年MM月dd日 hh:mm:ss EE": 2012年08月02日 11:27:41 星期四<br>
	 * @return String 当前字符串型日期
	 */
	public static String getDateFormat(Date date, String dateFormatType) {
		SimpleDateFormat simformat = new SimpleDateFormat(dateFormatType);
		return simformat.format(date);
	}

	/**
	 * 判断今天是不是周末
	 * 
	 * @return true/false
	 */
	public static boolean isTodayWeekend() {

		Calendar c = Calendar.getInstance(); // 获取当前日期
		int day = c.get(Calendar.DAY_OF_WEEK); // 获取当前日期星期,英国算法(周日为一周第一天)
		if (day == 7 || day == 1) { // 如果是周六或周日就返回true
			return true;
		}
		return false;
	}

	/**
	 * 获得间隔日期(主要是间隔N周、间隔N天)
	 * 
	 * @param specifiedStrDate
	 *            指定日期
	 * @param dateForamtType
	 *            指定日期格式
	 * @param intervalNum
	 *            间隔数(周或者天)
	 * @param calenderParam
	 *            指定修改日期格式的属性
	 *            Calendar.WEEK_OF_MONTH(周)或者Calendar.DAY_OF_MONTH(天)
	 * @return
	 */
	public static String getIntervalStrDate(String specifiedStrDate, String dateForamtType, int intervalNum,
			int calenderParam) {
		if (specifiedStrDate == null) {
			return null;
		}
		if (specifiedStrDate.trim().equals("")) {
			return null;
		}

		DateFormat df = new SimpleDateFormat(dateForamtType);

		Calendar cal = Calendar.getInstance();
		cal.setTime(DateUtil.turnStrDateToJavaUtilDate(specifiedStrDate, dateForamtType));
		cal.add(calenderParam, intervalNum);
		return df.format(cal.getTime());
	}

	/**
	 * 按照指定格式将字符串日期转换为SQL需要的日期对象
	 * 
	 * @param strDate
	 *            String,欲转换的字符串型日期
	 * 
	 * @param dateFormateType
	 *            String,指定的字符串日期格式
	 * @return java.sql.Date 转换后的java.sql.Date型日期
	 */
	public static java.sql.Date turnDateToSqlDate(String strDate, String dateFormateType) {
		if (strDate == null) {
			return null;
		}
		if (strDate.trim().equals("")) {
			return null;
		}

		return new java.sql.Date(turnStrDateToJavaUtilDate(strDate, dateFormateType).getTime());
	}

	/**
	 * 判断两个字符串型日期是否指同一天
	 * 
	 * @param strDate
	 *            字符串日期
	 * @param anotherStrDate
	 *            另一个字符日期
	 * 
	 * @return boolean true/false
	 */
	public static boolean isTheSameDay(String strDate, String anotherStrDate) {

		DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
		Date firstStrDate = null;
		Date secondStrDate = null;
		try {
			firstStrDate = df.parse(strDate);
			secondStrDate = df.parse(anotherStrDate);
		} catch (ParseException e) {

		}
		if (firstStrDate.getTime() > secondStrDate.getTime()) {

			return false;
		} else if (firstStrDate.getTime() < secondStrDate.getTime()) {

			return false;
		} else if (firstStrDate.getTime() == secondStrDate.getTime()) {

			return true;
		} else {

			return false;
		}
	}

	/**
	 * 按指定的字符串格式将字符串型日期转化为Date型日期
	 * 
	 * @Param dateStr 字符型日期
	 * @param dateFormatType
	 *            "yyyy-MM-dd" 或者 "yyyy-MM-dd hh:mm:ss"
	 * @return Date型日期
	 * @throws Exception
	 */
	public static Date turnStrDateToJavaUtilDate(String strDate, String dateFormatType) {

		Date javaUtilDate = null;
		DateFormat df = new SimpleDateFormat(dateFormatType);
		if (strDate != null && (!"".equals(strDate)) && dateFormatType != null && (!"".equals(dateFormatType))) {

			try {

				javaUtilDate = df.parse(strDate);
			} catch (ParseException e) {

			}
		}
		return javaUtilDate;
	}

	/**
	 * 将Date型日期转化指定格式的字符串型日期
	 * 
	 * @param javaUtilDate
	 *            Date,传入的Date型日期
	 * @param dateFormatType
	 *            "yyyy-MM-dd"或者<br>
	 *            "yyyy-MM-dd hh:mm:ss EE"或者<br>
	 *            "yyyy年MM月dd日 hh:mm:ss EE" <br>
	 *            (年月日 时:分:秒 星期 ,注意MM/mm大小写)
	 * @return String 指定格式的字符串型日期
	 */
	public static String turnJavaUtilDateToStrDate(Date javaUtilDate, String dateFormatType) {

		String strDate = "";
		if (javaUtilDate != null) {

			SimpleDateFormat sdf = new SimpleDateFormat(dateFormatType);
			strDate = sdf.format(javaUtilDate);
		}
		return strDate;
	}

	/**
	 * 获取当年指定月份第一天的字符串日期
	 * 
	 * @param specifiedMonth
	 *            指定月份
	 * @param dateFormatType
	 *            日期格式
	 * @return String 指定月份第一天的字符串日期
	 * @throws CSException
	 *             CSExceptionCode.EC_2000,CSExceptionCode.MSG_2000
	 */
	public static String getTheFirstDayOfSpecifiedMonth(int specifiedMonth, String dateFormatType) throws Exception {

		Date currentJavaUtilDate = getNowDate();
		Calendar cal = Calendar.getInstance();
		cal.setTime(currentJavaUtilDate);
		cal.set(Calendar.MONTH, specifiedMonth - 1);
		cal.set(Calendar.DAY_OF_MONTH, 1);

		Date resultDate = cal.getTime();
		String result = turnJavaUtilDateToStrDate(resultDate, dateFormatType);
		return result;
	}

	/**
	 * 获取当年指定月份的最后一天字符串日期
	 * 
	 * @param specifiedMonth
	 *            指定月份
	 * @param dateFormatType
	 *            日期格式
	 * @return String 时间字符串
	 * @throws CSException
	 *             CSExceptionCode.EC_2000,CSExceptionCode.MSG_2000
	 */
	public static String getTheLastDayOfSpecifiedMonth(int specifiedMonth, String dateFormatType) throws Exception {

		Date date = null;
		date = turnStrDateToJavaUtilDate(getTheFirstDayOfSpecifiedMonth(specifiedMonth, dateFormatType),
				dateFormatType);
		Calendar calendar = Calendar.getInstance();
		calendar.setTime(date);
		calendar.add(Calendar.MONTH, 1);
		calendar.add(Calendar.DAY_OF_YEAR, -1);
		String result = turnJavaUtilDateToStrDate(calendar.getTime(), "yyyy-MM-dd");
		return result;
	}

	/**
	 * 获取当前月第一天的字符串日期
	 * 
	 * @return String 当前月第一天的字符串日期。例如:当前日期是2012-08-2,则返回值为2012-08-1
	 */
	public static String getTheFirstDayOfCurrentMonth() {

		Calendar cal = Calendar.getInstance();// 获取当前日期
		cal.set(Calendar.DAY_OF_MONTH, 1);// 设置为1号,即是本月第一天
		DateFormat df = new SimpleDateFormat("yyyy-MM-dd");// 格式化
		return df.format(cal.getTime());
	}

	/**
	 * 获取当前月最后一天的字符串日期
	 * 
	 * @return String 当前月最后一天的日期。 例如:当前日期是2012-08-2,则返回值为2012-08-31
	 */
	public static String getTheLastDayOfCurrentMonth() {

		DateFormat df = new SimpleDateFormat("yyyy-MM-dd");//
		Calendar cal = Calendar.getInstance();// 获取当前日期,例如2012-08-02
		cal.set(Calendar.DAY_OF_MONTH, 1);// 转变为当前月的第一天,例如2012-08-01
		cal.add(Calendar.MONTH, 1);// 转变为下个月的第一天,例如2012-09-01
		cal.add(Calendar.DAY_OF_MONTH, -1);// 下个月第一天,倒数一天,即为当前月的最后一天。例如2012-08-31
		return df.format(cal.getTime());
	}

	/**
	 * 验证传入日期是否为当前月最后一天
	 * 
	 * @param targetObj
	 *            传入日期可为字符串、Date
	 * @param formtStr
	 *            yyyy-MM-dd hh:mm:ss
	 * @return true/false
	 */
	public static boolean isTheLastDayOfCurrentMonth(Object targetObj, String formtStr) {

		boolean flag = false;
		if (targetObj == null) {// 如果传入日期参数为null,则返回false
			return flag;
		} else if ("".equals(targetObj.toString())) {// 如果传入日期参数为空字符串,则返回false
			return flag;
		}

		String srcDate = "";
		if (targetObj.getClass() == String.class) {
			srcDate = DateUtil.turnJavaUtilDateToStrDate(
					DateUtil.turnStrDateToJavaUtilDate(targetObj.toString(), "yyyy-MM-dd"), formtStr);
		} else if (targetObj.getClass() == Date.class) {
			srcDate = DateUtil.turnJavaUtilDateToStrDate((Date) targetObj, formtStr);
		} else {
			srcDate = DateUtil.turnJavaUtilDateToStrDate(getNowDate(), "yyyy-MM-dd");
		}
		if (srcDate.compareTo(DateUtil.getTheLastDayOfCurrentMonth()) == 0) {// 和当前月最后一天比较的结果为0,则是当前月最后一天
			flag = true;
			return flag;
		} else {
			return flag;
		}
	}

	/**
	 * 获取当前时间16位字符串  时间16位+4位随机数2012091811320043154
	 * 
	 * @return String e.g."2012082110290016"
	 */
	public static String getCurrentDateTime16Str() {

		SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSS");

		/* 生成随机数 */
		int[] array = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
		Random rand = new Random();
		for (int i = 10; i > 1; i--) {
			int index = rand.nextInt(i);
			int tmp = array[index];
			array[index] = array[i - 1];
			array[i - 1] = tmp;
		}
		int result = 0;
		for (int i = 0; i < 4; i++) {
			result = result * 10 + array[i];
		}

		return sdf.format(getNowDate()) + result;
	}

	/**
	 * 指定日期、相加月数值、格式,得到相加日期 例如:2011-06-19 2 yyyy-MM-dd 结果:2011-08-19 2011-06-19
	 * 12 yyyy-MM-dd 结果:2012-06-19
	 * 
	 * @param date
	 *            指定日期
	 * @param formtStr
	 *            格式
	 * @param number
	 *            数组
	 * @param calender
	 *            指定修改日期格式数组
	 * @author leiyunshi
	 * @return
	 */
	public static String tragetDate(String date, String formtStr, int number, int calender) {
		if (date == null) {
			return null;
		}

		if (date.trim().equals("")) {
			return null;
		}
		DateFormat df = new SimpleDateFormat(formtStr);// "yyyy-MM-dd"

		Calendar cal = Calendar.getInstance();
		cal.setTime(DateUtil.toDate(date));
		cal.add(calender, number);
		// System.out.println(df.format(cal.getTime()));
		return df.format(cal.getTime());
	}

	/**
	 * 按照"yyyy-MM-dd"格式将字符串date转换为日期对象
	 * 
	 * @param date
	 * @return
	 */
	public static Date toDate(String date) {
		if (date == null) {
			return null;
		}
		if (date.trim().equals("")) {
			return null;
		}
		SimpleDateFormat simformat = new SimpleDateFormat("yyyy-MM-dd");
		try {
			return simformat.parse(date);
		} catch (ParseException e) {
			e.printStackTrace();
		}
		return null;
	}

	/**
	 * 按照"yyyy-MM-dd"格式将字符串date转换为日期对象
	 * 
	 * @param date
	 * @return
	 */
	public static Date toDate(String date, String format) {
		if (date == null) {
			return null;
		}
		if (date.trim().equals("")) {
			return null;
		}
		SimpleDateFormat simformat = new SimpleDateFormat(format);
		try {
			return simformat.parse(date);
		} catch (ParseException e) {
			e.printStackTrace();
		}
		return null;
	}
	
	/**
	 * 格式化CST( Thu Aug 27 18:05:49 CST 2015 )格式字符串
	 * @param date
	 * @param format
	 * @return
	 * @throws ParseException
	 */
	public static String formatCSTTime(String date, String format) throws ParseException{
		SimpleDateFormat sdf = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);
		Date d = sdf.parse(date);
		return DateUtil.getDateFormat(d, format);
	}

	/**
	 * 取得两个时间段的时间间隔
	 * 
	 * @author color
	 * @param t1
	 *            时间1
	 * @param t2
	 *            时间2
	 * @return t2 与t1的间隔年数
	 * @throws ParseException
	 *             如果输入的日期格式不是0000-00-00 格式抛出异常
	 */
	public static int getBetweenYears(String t1, String t2) throws ParseException {
		DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
		Date d1 = format.parse(t1);
		Date d2 = format.parse(t2);
		Calendar c1 = Calendar.getInstance();
		Calendar c2 = Calendar.getInstance();
		c1.setTime(d1);
		c2.setTime(d2);
		// 保证第二个时间一定大于第一个时间
		if (c1.after(c2)) {
			c1 = c2;
			c2.setTime(d1);
		}
		int betweenYears = c2.get(Calendar.YEAR) - c1.get(Calendar.YEAR);

		return betweenYears;
	}

	/**
	 * 取得两个时间段的时间间隔
	 * 
	 * @author color
	 * @param t1
	 *            时间1
	 * @param t2
	 *            时间2
	 * @return t2 与t1的间隔天数
	 * @throws ParseException
	 *             如果输入的日期格式不是0000-00-00 格式抛出异常
	 */
	public static int getBetweenDays(String t1, String t2) throws ParseException {
		DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
		int betweenDays = 0;
		Date d1 = format.parse(t1);
		Date d2 = format.parse(t2);
		Calendar c1 = Calendar.getInstance();
		Calendar c2 = Calendar.getInstance();
		c1.setTime(d1);
		c2.setTime(d2);
		// 保证第二个时间一定大于第一个时间
		if (c1.after(c2)) {
			c1 = c2;
			c2.setTime(d1);
		}
		int betweenYears = c2.get(Calendar.YEAR) - c1.get(Calendar.YEAR);
		betweenDays = c2.get(Calendar.DAY_OF_YEAR) - c1.get(Calendar.DAY_OF_YEAR);
		for (int i = 0; i < betweenYears; i++) {
			c1.set(Calendar.YEAR, (c1.get(Calendar.YEAR) + 1));
			betweenDays += c1.getMaximum(Calendar.DAY_OF_YEAR);
		}
		return betweenDays;
	}

	public static int getBetweenDays(String t1, String t2, String formatstr) {
		DateFormat format = new SimpleDateFormat(formatstr);
		int betweenDays = 0;
		Date d1, d2;
		Calendar c1, c2;
		try {
			d1 = format.parse(t1);
			d2 = format.parse(t2);
			c1 = Calendar.getInstance();
			c2 = Calendar.getInstance();
			c1.setTime(d1);
			c2.setTime(d2);
			// 保证第二个时间一定大于第一个时间
			if (c1.after(c2)) {
				c1 = c2;
				c2.setTime(d1);
			}
			int betweenYears = c2.get(Calendar.YEAR) - c1.get(Calendar.YEAR);
			betweenDays = c2.get(Calendar.DAY_OF_YEAR) - c1.get(Calendar.DAY_OF_YEAR);
			for (int i = 0; i < betweenYears; i++) {
				c1.set(Calendar.YEAR, (c1.get(Calendar.YEAR) + 1));
				betweenDays += c1.getMaximum(Calendar.DAY_OF_YEAR);
			}
		} catch (ParseException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return betweenDays;
	}

	/**
	 * 判断是否是日期
	 * 
	 * @param String
	 *            dateStr 日期字符串
	 * @return
	 */
	public static boolean checkDate(String dateStr) {
		String regex = "[1-2]{1}\\d{3}[0-1]{1}\\d{1}[0-3]{1}\\d{1}";
		return Pattern.matches(regex, dateStr);
	}

	/**
	 * 获取当前时间戳
	 * 
	 * @return String 时间戳字符串
	 */
	public static String getCurrentStringTimestamp() {
		return new SimpleDateFormat("yyyyMMddHHmmss").format(getNowDate());
	}

	/**
	 * 获取当前日期戳
	 * 
	 * @return String 日期戳字符串
	 */
	public static String getCurrentStringDate() {
		return new SimpleDateFormat("yyyyMMdd").format(getNowDate());
	}

	/**
	 * 获取当前月份的最后一天
	 * 
	 * @return String 日期戳字符串
	 */
	public static Integer getDaycountInMonth() {
		Calendar ca = Calendar.getInstance();
		ca.set(Calendar.DAY_OF_MONTH, ca.getActualMaximum(Calendar.DAY_OF_MONTH));
		SimpleDateFormat format = new SimpleDateFormat("dd");
		String last = format.format(ca.getTime());
		return Integer.parseInt(last);
	}

	/**
	 * 获取指定日期的前几天或者后几天
	 * 
	 * @return String 日期戳字符串
	 */
	public static String getCoupleDate(Date date, int day, String formtStr) {
		DateFormat format = new SimpleDateFormat(formtStr);
		Calendar c = Calendar.getInstance();
		c.setTime(date);
		c.add(Calendar.DAY_OF_MONTH, day);
		return format.format(c.getTime());
	}

	public static String getDateToWeek(Date date) {
		Calendar calendar = Calendar.getInstance();
		calendar.setTime(date);
		String week = "";
		switch (calendar.get(Calendar.DAY_OF_WEEK)) {
		case 1:
			week = "星期日";
			break;
		case 2:
			week = "星期一";
			break;
		case 3:
			week = "星期二";
			break;
		case 4:
			week = "星期三";
			break;
		case 5:
			week = "星期四";
			break;
		case 6:
			week = "星期五";
			break;
		case 7:
			week = "星期六";
			break;
		}
		return week;
	}
    
	public static String StrDateToDate(String value) {
		Date date;
		try {
			date = DateUtils.parseDate(value, new String[]{"yyyyMMdd"});
			DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
			return dateFormat.format(date);
		} catch (ParseException e) {
			return null;
		}	
	}
}



import java.text.DecimalFormat;

public class FormatNumberUtils {

	public static String fixLength(int len, int number) {
		String strFormat = "";
		for(int i = 0; i < len; i++) {
			strFormat += "0";
		}
		DecimalFormat df = new DecimalFormat(strFormat);
		return df.format(number);
	}
}

如何更改序列

alter sequence SEQ_PIMSAPPLYNO increment by 2000000;
alter sequence SEQ_PIMSAPPLYNO increment by 1;
COMMIT ;
select SEQ_PIMSAPPLYNO.nextval from dual;

删除序列

drop sequence SEQ_PIMSAPPLYNO;
create sequence SEQ_PIMSAPPLYNO
minvalue 1
maxvalue 999999999999999999999999999
start with 2000000
increment by 1

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值