ORACLE 用32進制表示月中的一天
WHEN 'YMD' THEN
v_year := to_char(SYSDATE, 'Y');
v_month := FN_CONVERT_DECIMAL_TO_BASE(to_number(to_char(SYSDATE, 'MM')),32,1);
v_day := FN_CONVERT_DECIMAL_TO_BASE(to_number(to_char(SYSDATE, 'DD')),32,1);
v_str := v_year || v_month || v_day;
WHEN 'YMDD' THEN
v_year := to_char(SYSDATE, 'Y');
v_month := FN_CONVERT_DECIMAL_TO_BASE(to_number(to_char(SYSDATE, 'MM')),16,1);
v_day :=to_char(SYSDATE, 'DD');
FUNCTION FN_CONVERT_DECIMAL_TO_BASE (P_DECIMAL_NUM IN INTEGER, P_DIGITAL_TYPE IN VARCHAR2, P_LEN IN INTEGER) RETURN VARCHAR2
IS v_result_str VARCHAR2 (20) := '0';
v_replace_str VARCHAR2 (8000);
v_baseindex INT := 1;
v_quotient INT := p_decimal_num;
v_digit INT := P_LEN - 1;
v_digit_loop INT := 0;
v_basenumber INT := 0;
v_basebeginnumber INT := 10;
v_decodesql VARCHAR2 (1000);
v_remainder INT := 0;
v_baseloopnumber INT := 0;
v_base_10 VARCHAR2(10) := '0123456789';
v_base_16 VARCHAR2(16) := '0123456789ABCDEF';
v_base_30 VARCHAR2(30) := '0123456789ABCDEFGHJKLMNPQRTWXY';
v_base_32 VARCHAR2(32) := '0123456789ABCDEFGHJKLMNPRSTVWXYZ';
v_base_33 VARCHAR2(33) := '0123456789ABCDEFGHJKLMNPQRSTVWXYZ';
v_base_34 VARCHAR2(34) := '0123456789ABCDEFGHJKLMNPQRSTUVWXYZ';
v_base_36 VARCHAR2(36) := '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ';
v_base_code varchar2(62) := '';
BEGIN
CASE
P_DIGITAL_TYPE WHEN '10' THEN
v_basenumber := LENGTH(v_base_10);
v_base_code := v_base_10;
WHEN '16' THEN
v_basenumber := LENGTH(v_base_16);
v_base_code := v_base_16;
WHEN '30' THEN
v_basenumber := LENGTH(v_base_30);
v_base_code := v_base_30;
WHEN '32' THEN
v_basenumber := LENGTH(v_base_32);
v_base_code := v_base_32;
WHEN '33' THEN
v_basenumber := LENGTH(v_base_33);
v_base_code := v_base_33;
WHEN '34' THEN
v_basenumber := LENGTH(v_base_34);
v_base_code := v_base_34;
WHEN '36' THEN
v_basenumber := LENGTH(v_base_36);
v_base_code := v_base_36;
END CASE;
v_baseloopnumber := v_basenumber - 10;
v_digit_loop := v_digit;
IF v_basenumber = 10
THEN
RETURN LPAD(P_DECIMAL_NUM,P_LEN,'0');
ELSE
v_result_str := LPAD(v_result_str,v_digit,'0');
END IF;
LOOP
v_decodesql := v_decodesql || '''' || v_basebeginnumber || ''',''' || SUBSTR (v_base_code, v_basebeginnumber + 1, 1) || ''',';
v_basebeginnumber := v_basebeginnumber + 1;
v_baseloopnumber := v_baseloopnumber - 1;
EXIT WHEN v_baseloopnumber = 0; END LOOP;
LOOP
v_remainder := MOD (v_quotient, v_basenumber);
EXECUTE IMMEDIATE 'select Decode(' || v_remainder || ' ,' || v_decodesql || v_remainder || ') From dual ' INTO v_replace_str;
v_result_str := SUBSTR (v_result_str, 0, v_digit_loop) || v_replace_str || SUBSTR (v_result_str, v_digit_loop + 2, v_digit - v_digit_loop); v_quotient := FLOOR (v_quotient / v_basenumber); v_digit_loop := v_digit_loop - 1; EXIT WHEN v_digit_loop < 0; END LOOP;
RETURN v_result_str; END FN_CONVERT_DECIMAL_TO_BASE;
ORACLE 用32進制表示月中的一天的更多相关文章
- Oracle 中的进制转换
Oracle 中的进制转换 */--> Oracle 中的进制转换 Table of Contents 1. 进制名 2. 10进制与16进制互相转换 2.1. 10进制转换为16进制 2.2. ...
- 64位主机64位oracle下装32位客户端ODAC(NFPACS版)
64位主机64位oracle下装32位客户端ODAC(NFPACS版) by dd 1.下载Oracle Data Access Components(ODAC) Xcopy的两个版本: x86:(我 ...
- 51nod1086(多重背包&二進制)
題目鏈接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1086 題意:中文題誒- 思路:很顯然這是一道多重背包題,不過這 ...
- php利用32进制实现对id加密解密
前言 最近在项目中遇到一个问题,当前用户分享一个邀请码给好友,好友根据邀请码注册成为新用户之后,则成为当前用户的下级,特定条件下,可以得到下级用户的一系列返利.这里要实现的就是根据当前用户的id,生成 ...
- (64位oracle使用32位的PLSQL)安装64位的oracle数据库软件,使用32位的PLSQL Developer连接方法
因为PLSQL Developer没有提供64位的,于是依据网上的资料做了一下整理,发上来 1.下载并安装Oracle 11g R2 64位,在server上安装时忽略硬件检測失败信息: 2.下载Or ...
- Windows Server 2008 R2 64位操作系统安装Oracle 11g 64位数据库,在客户终端上安装Oracle 11g 32位,才能安装P/L Sql Developer并配置
1.下载Oracle 11g R2 for Windows的版本 下载地址: http://www.oracle.com/technetwork/database/enterprise-edition ...
- 让 Oracle 11g 32位运作在64位 Windows 上
并非不能运行. 本人安装版未曾尝试,但绿色版倒是运行成功了. 很简单:注册表的位置发生了变化而已! 默认(32位.64位),oracle会读取以下注册表的位置: [HKEY_LOCAL_MA ...
- Guid和Oracle中16进制字符的转换
我们知道在Oracle中存的guid是16进制字符串,而在我们的C#代码中存的是guid对象,这样我会就要进行转换, 下面给出了两者进行转换的方法: public class Guid2RawProc ...
- [Oracle] - 使用32位 PLSQL(PL/SQL Developer)登陆64位Oracle失败之解决
配置环境 Oracle服务端oracle_winx64_12c_database.iso Oracle客户端instantclient-basiclite-nt-12.1.0.1.0.zip 集成开发 ...
随机推荐
- Centos610无桌面安装VSFTP
1.检查可以安装的VSFTP版本 yum search vsftp 2.开始安装VSFTP yum install -y vsftpd 3.配置说明 cd /etc/vsftpd vsftpd.con ...
- 模块学习-json pickle
json json序列化 import json def sayhi(name): print("hello",name) info = { 'name':'mogu', 'age ...
- 页面分享功能,分享好友、朋友圈判断,用share_type做标记 这里用的是jweixin-1.3.2.js
这里用的是jweixin-1.3.2.js trigger: function (res) { //判断分享的状态,好友.朋友圈 localStorage.setItem("share_ty ...
- 使用命令将单个java文件打包为jar
思路:先将java文件编译为class文件,然后再打包为jar 参考博文:https://www.cnblogs.com/sxdcgaq8080/p/8126770.html http://www.m ...
- redhat 7.6 流量监控命令、软件(2) iftop 监控网络IP实时流量
1.安装iftop,先要安装flex.bison.libpcap编译安装 解压红箭头的两个文件 tar -zxvpf iftop-0.16.tar.gz tar -zxvpf libpcap ...
- 浅谈CVE-2018-12613文件包含/buuojHCTF2018签到题Writeup
文件包含 蒻姬我最开始接触这个 是一道buuoj的web签到题 进入靶机,查看源代码 <!DOCTYPE html> <html lang="en"> &l ...
- php 基础知识 post 和get 两种传输方式的区别
1.post更安全(不会作为url的一部分,不会被缓存.保存在服务器日志.以及浏览器浏览记录中) 2.post发送的数据量更大(get有url长度限制) 3.post能发送更多的数据类型(get只能发 ...
- CSS各种小技巧
/* *背景的透明度设置 */ -moz-opacity: 0.8; opacity:.80; filter: alpha(opacity=80); 待续...
- Python编程使用PyQT制作视频播放器
最近研究了Python的两个GUI包,Tkinter和PyQT.这两个GUI包的底层分别是Tcl/Tk和QT.相比之下,我觉得PyQT使用起来更加方便,功能也相对丰富.这一篇用PyQT实现一个视频播放 ...
- Python经典排序算法
https://www.cnblogs.com/onepixel/p/7674659.html这个文章很nice https://www.bilibili.com/video/av685670?fro ...