Oracle生成流水号函数
1:日期范围上 smalldatetime的有效时间范围1900/1/1~2079/6/6 datetime的有效时间范围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_col VARCHAR2, v_table_name VARCHAR2) /* * 参数说明: * v_type: 编码前缀 * v_number_col:编码所在列名 * v_table_name:编码所在表名 */ RETURN VARCHAR2 IS v_old_no VARCHAR2(50); --原编码 v_old_num NUMBER; -- 原编码后五位编号 v_new_num VARCHAR2(10); --新编码后五位编号 v_maked_no VARCHAR2(50); --新编码 v_date_no VARCHAR2(20); --当前日期编号 v_sql VARCHAR2(4000); BEGIN v_sql := ‘SELECT MAX(‘ || v_number_col || ‘) FROM ‘ || v_table_name; EXECUTE IMMEDIATE v_sql INTO v_old_no; v_sql := ‘SELECT SUBSTR(TO_CHAR(SYSDATE,‘‘YYMMDD‘‘), 1, 6) AS DATE_NO FROM DUAL‘; EXECUTE IMMEDIATE v_sql INTO v_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) < 5 LOOP v_new_num := ‘0‘ || v_new_num; END LOOP; IF v_old_no IS NULL OR substr(v_old_no, 5, 6) <> v_date_no THEN v_maked_no := v_type || v_date_no || ‘00001‘; ELSE v_maked_no := v_type || v_date_no || v_new_num; END IF; RETURN(v_maked_no); EXCEPTION WHEN OTHERS THEN dbms_output.put_line(SQLERRM); END fn_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=y exp 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
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。