java oracle 流水号_Oracle生成流水号函数

1:日期范围上

smalldatetime的有效时间范围1900/1/1~2079/6/6datetime的有效时间范围1753/1/1~9999/12/31

2:精准度上

smalldatetime只精准到分,而datetime则可精准到3位的毫秒。3:存储空间上

smalldatetime占用4个字节,前2个字节存储base date(1900年1月1日)之后的天数。后2个字节存储午夜后的分钟数。

datetime占用8个字节,前4个字节存储base date(即1900年1月1日)之前或之后的天数,后4个字节存储午夜后的毫秒数

Oracle生成流水号函数CREATE OR REPLACE FUNCTION fn_no_make(v_type VARCHAR2,

v_number_colVARCHAR2,

v_table_nameVARCHAR2)/** 参数说明:

* v_type: 编码前缀

* v_number_col:编码所在列名

* v_table_name:编码所在表名*/

RETURN VARCHAR2 ISv_old_noVARCHAR2(50); --原编码

v_old_num NUMBER; --原编码后五位编号

v_new_num VARCHAR2(10); --新编码后五位编号

v_maked_no VARCHAR2(50); --新编码

v_date_no VARCHAR2(20); --当前日期编号

v_sql VARCHAR2(4000);BEGINv_sql := 'SELECT MAX(' || v_number_col || ') FROM' ||v_table_name;EXECUTEIMMEDIATE v_sqlINTOv_old_no;

v_sql := 'SELECT SUBSTR(TO_CHAR(SYSDATE,''YYMMDD''), 1, 6) AS DATE_NO FROM DUAL';EXECUTEIMMEDIATE v_sqlINTOv_date_no;

v_old_num := to_number(substr(v_old_no, 11, 5));

v_new_num := to_char(v_old_num + 1);WHILE length(v_new_num) < 5LOOP

v_new_num := '0' ||v_new_num;ENDLOOP;IF v_old_no IS NULL ORsubstr(v_old_no,5, 6) <>v_date_noTHENv_maked_no := v_type || v_date_no || '00001';ELSEv_maked_no := v_type || v_date_no ||v_new_num;END IF;RETURN(v_maked_no);

EXCEPTIONWHEN OTHERS THENdbms_output.put_line(SQLERRM);ENDfn_no_make;1.数据库导入,导出命令

数据导出:

a. 将数据库TEST完全导出,用户名system 密码manager 导出到D:\daochu.dmp中exp test/test@ORACLE_192.168.28.1 file=d:\daochu.dmp full=y

b. 将数据库中system用户与sys用户的表导出exp test/test@ORACLE_192.168.28.1 file=d:\daochu.dmp owner=(system,sys)

数据导入:

a 将D:\daochu.dmp 中的数据导入 TEST数据库中。

imp dev/dev@ORACLE_192.168.28.2 file=d:\daochu.dmp

imp dev/dev@ORACLE_192.168.28.2 full=y file=file= d:\data\newsmgnt.dmp ignore=y

上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。

在后面加上 ignore=y 就可以了。

b 将d:\daochu.dmp中的表table1 导入

imp dev/dev@TEST file=d:\daochu.dmp tables=(table1)2.数据库表中Clob,Blob 导入导出命令exp 数据库用户名/密码@配置名称 file=输出文件路径 log=日志文件路径 tables=(数据库表名) query=\"查询条件\"

imp 数据库用户名/密码@配置名称 file=输入文件路径 log=日志文件路径 tables=(数据库表名) ignore=yexp test/test@ORACLE_192.168.28.1 file=c:\11.dmp log=c:\11.log tables=(table1) query=\"where createdby='sysadmin' and to_char(createtime,'YYYY-MM-DD')='2012-05-17'\"

imp dev/dev@ORACLE_192.168.28.2 file=c:\11.dmp log=c:\121.log tables=(table1) ignore=y

用cmd.exe 执行就可以,注意的地方就是query 地方 \"

先执行exp 后执行imp

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值