首页 > 数据库 >[20240518]任意进制转换xtoy.sql脚本.txt

[20240518]任意进制转换xtoy.sql脚本.txt

时间:2024-05-18 21:51:44浏览次数:26  
标签:20240518 16 -- LEVEL xtoy base && sql

[20240518]任意进制转换xtoy.sql脚本.txt

--//前几天尝试改进10进制转任意进制,以及其他进制转10进制脚本,有了这两个脚本就可以通过10进制实现任意进制的转换.

$ cat 10tox.sql

set term off
column 2 new_value 2
select null "2" from dual where 1=2;
select nvl('&2',16) "2" from dual;
set term on

column base10 format a30
column base&&2 format a30

select to_char('&&1') base10,
    listagg(
        substr(
          case &&2 when 32 then
            '0123456789abcdfghjkmnpqrstuvwxyz'
          else
            '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@_'
          end,
          mod(
            trunc(&&1/power(&&2,level-1)),
            &&2
          ) + 1 ,
          1
        )
    ) within group (order by level desc) base&&2
  from dual
  connect by level <= ceil(log(&&2,&&1+1))
;
--//注:32进制使用oracle sql_id编码.

$ cat xto10.sql
set term off
column 2 new_value 2
select null "2" from dual where 1=2;
select nvl('&2',16) "2" from dual;
set term on

column base10 format  a30
column base&&2 format a30

SELECT CASE &2 WHEN 16 THEN LOWER ('&&1') ELSE '&&1' END base&2, TO_CHAR (SUM (n * POWER (&2, p))) base10
  FROM (    SELECT   INSTR
                     (
                        CASE &&2
                           WHEN 32
                           THEN
                              '0123456789abcdfghjkmnpqrstuvwxyz'
                           WHEN 16
                           THEN
                              '0123456789abcdef'
                           ELSE
                              '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@_'
                        END
                       ,SUBSTR
                        (
                           CASE &2 WHEN 16 THEN LOWER ('&&1') ELSE '&&1' END
                          ,LEVEL
                          ,1
                        )
                     )
                   - 1
                      N
                  ,LENGTH ('&&1') - LEVEL P
                  ,SUBSTR ('&&1', LEVEL, 1) C
              FROM DUAL
        CONNECT BY LEVEL <= LENGTH ('&&1'));
--//16进制特殊一些,考虑英文字符大小写问题.

--//两者结合编写代码如下:
$ cat xtoy.sql
column base&&2 format a50
column base&&3 format a50
column base10  format a50

-- select to_char('&&1') base10,
--     listagg(
--         substr(
--           case &&2 when 32 then
--             '0123456789abcdfghjkmnpqrstuvwxyz'
--           else
--             '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@_'
--           end,
--           mod(
--             trunc(&&1/power(&&2,level-1)),
--             &&2
--           ) + 1 ,
--           1
--         )
--     ) within group (order by level desc) base&&2
--   from dual
--   connect by level <= ceil(log(&&2,&&1+1))
-- ;

column base&&2 format a50
column base&&3 format a50
column base10  format a50

-- select to_char('&&1') base10,
--     listagg(
--         substr(
--           case &&2 when 32 then
--             '0123456789abcdfghjkmnpqrstuvwxyz'
--           else
--             '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@_'
--           end,
--           mod(
--             trunc(&&1/power(&&2,level-1)),
--             &&2
--           ) + 1 ,
--           1
--         )
--     ) within group (order by level desc) base&&2
--   from dual
--   connect by level <= ceil(log(&&2,&&1+1))
-- ;

    SELECT base&2
          ,LISTAGG
           (
              SUBSTR
              (
                 CASE &&3
                    WHEN 32
                    THEN
                       '0123456789abcdfghjkmnpqrstuvwxyz'
                    ELSE
                       '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@_'
                 END
                ,MOD (TRUNC (base10n / POWER (&&3, LEVEL - 1)), &&3) + 1
                ,1
              )
           )
           WITHIN GROUP (ORDER BY LEVEL DESC)
              base&&3
          ,TO_CHAR (base10n) base10
      FROM (SELECT CASE &2 WHEN 16 THEN LOWER ('&&1') ELSE '&&1' END base&2
                  ,SUM (n * POWER (&2, p)) base10n
              FROM (    SELECT   INSTR
                                 (
                                    CASE &&2
                                       WHEN 32
                                       THEN
                                          '0123456789abcdfghjkmnpqrstuvwxyz'
                                       WHEN 16
                                       THEN
                                          '0123456789abcdef'
                                       ELSE
                                          '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@_'
                                    END
                                   ,SUBSTR
                                    (
                                       CASE &2
                                          WHEN 16 THEN LOWER ('&&1')
                                          ELSE '&&1'
                                       END
                                      ,LEVEL
                                      ,1
                                    )
                                 )
                               - 1
                                  N
                              ,LENGTH ('&&1') - LEVEL P
                              ,SUBSTR ('&&1', LEVEL, 1) C
                          FROM DUAL
                    CONNECT BY LEVEL <= LENGTH ('&&1')))
CONNECT BY LEVEL <= CEIL (LOG (&&3, base10n + 1))
  GROUP BY base&2, TO_CHAR (base10n);

--//测试看看:
SYS@test> @ xtoy  1f 16 2
BASE16 BASE2 BASE10
------ ----- --------
1f     11111 31

SYS@test> @ xtoy  1f 16 4
BASE16 BASE4 BASE10
------ ----- ------
1f     133   31

SYS@test> @ xtoy  1f 16 8
BASE16 BASE8 BASE10
------ ----- ------
1f     37    31

SYS@test> @ xtoy  _@1 64 10
BASE64 BASE10 BASE10
------ ------ ------
_@1    262017 262017

SYS@test> @ xtoy  262017 10 64
BASE10 BASE64 BASE10
------ ------ ------
262017 _@1    262017

--//看看sql_id的计算.
SCOTT@test01p> select * from dept;
    DEPTNO DNAME                LOC
---------- -------------------- -------------
        10 ACCOUNTING           NEW YORK
        20 RESEARCH             DALLAS
        30 SALES                CHICAGO
        40 OPERATIONS           BOSTON

SCOTT@test01p> @ hash
HASH_VALUE SQL_ID        CHILD_NUMBER KGL_BUCKET PLAN_HASH_VALUE HASH_HEX   SQL_EXEC_START      SQL_EXEC_ID
---------- ------------- ------------ ---------- --------------- ---------- ------------------- -----------
3599690174 3154rqzb8xudy            0      59838      3383998547  d68ee9be  2024-05-15 21:33:53    16777217

SYS@test> @ xtoy 3154rqzb8xudy 32 16
BASE32         BASE16           BASE10
-------------- ---------------- -------------------
3154rqzb8xudy  309497b7d68ee9be 3500589626208217534

--//d68ee9be = HASH_HEX

SYS@test> @ xtoy d68ee9be 16 10
BASE16         BASE10           BASE10
-------------- ---------------- -------------------
d68ee9be       3599690174       3599690174

SYS@test> @ xtoy 309497b7d68ee9be 16 32
BASE16           BASE32        BASE10
---------------- ------------- -------------------
309497b7d68ee9be 3154rqzb8xudy 3500589626208217534


标签:20240518,16,--,LEVEL,xtoy,base,&&,sql
From: https://www.cnblogs.com/lfree/p/18199819

相关文章

  • [20240510]SQL语句存在问题与共享池内存分配.txt
    [20240510]SQL语句存在问题与共享池内存分配.txt--//五一前遇到的问题,生产系统应用程序升级,但是3个表忘记建立,而编写的程序可能存在问题,导致频繁调用这些根本不可能执行的sql--//语句.很奇怪的是应用前台根本不报错,真不知道开发如何写代码,难道没做例外处理以及记录吗?--//测......
  • [20240511]测试问题sql语句对数据库性能影响.txt
    [20240511]测试问题sql语句对数据库性能影响.txt--//五一前遇到的问题,生产系统应用程序升级,但是3个表忘记建立,而编写的程序可能存在问题,导致频繁调用这些根本不可能执行的sql--//语句,正常情况下应该报ORA-00942:tableorviewdoesnotexist,很奇怪的同事反映应用前台根本......
  • [20240511]建立10进制转任意进制10tox.sql脚本.txt
    [20240511]建立10进制转任意进制10tox.sql脚本.txt--//翻开以前笔记,找到1个脚本10x.sql(改名10tox.sql),可以实现10进制转任意进制.受字符集限制最大64进制.--//bashshell64进制编码从0开始.0-9,a-z,A-Z.这样仅仅62个编码.还剩下2个.@_,以该编码为基础来实现--//bashshel......
  • [20250511]建立完善s2h.sql脚本.txt
    [20250511]建立完善s2h.sql脚本.txt--//写过一个sql_id计算hash_value的bashshell脚本,实际上oracle使用dbms_utility.SQLID_TO_SQLHASH就可以实现,$cats2h.sql--Copyright2023lfree.Allrightsreserved.--LicensedundertheApacheLicense,Version2.0.SeeLICENSE......
  • [20240512]建立完善sql_idz.sh脚本.txt
    [20240512]建立完善sql_idz.sh脚本.txt--//使用该脚本计算存在小问题,cat文件中如果有ascii=0,cat时会过滤掉,一般tablenamespac是1.--//在尾部追加\01\0\0\0,而sql语句追加的是\0.我以前代码写死的.修改更加灵活一些.--//增加参数3,如果不输入缺省等于\0.--//增加计算exact_mat......
  • MySQL面试必备三之事务
    本文首发于公众号:Hunter后端原文链接:MySQL面试必备三之事务这一篇笔记介绍一下MySQL的事务,面试中常被问到关于事务的几个问题如下:事务是什么为什么需要事务,事务有什么作用事务的特点事务可能带来哪些问题事务有哪些隔离级别,这些隔离级别都可以解决哪些问题可重复读隔......
  • mysql外部访问踩坑
    起因项目用.Net开发,在mac上运行,可能是版本问题,想试试在windows下部署,就用parallels起了个windows,但windows却无法连接宿主mac上的mysql,最后折腾了一天才解决。排查宿主机和虚拟机互ping这是排查的一个方向,但parallels默认就是能互联的,如果ping不通,需要配置为共享网络宿......
  • 20240518模拟赛
    C240518A.传送门(portal)构造一个图使得点\(1\)到\(2\)的最短路正好有\(k\)条,使构造出的图点的个数\(N\len_5\)考虑\(k=2^t\)那么可以轻松构造出如下的图对于其他的情况可以考虑二进制拆分,如\(k=10\)时为了,使最短路长度固定加入点\(9\)对\(k=10^9\),只需构造\(80\)个点,可以......
  • Less靶场SQL注入通关宝典
    这篇文章是一个sqil-labs靶场的保姆级教学,从安装、配置、场景通关都有详细的介绍,其中场景通关是我们这篇文章的重点。首先我们要了解sqli-labs靶场是什么?sqli-labs靶场是刚刚接触SQL注入的新手,了解SQL注入、练习SQL注入的一个很方便,很实用的一个靶场,配置简单,操作简单......
  • SQL 学习笔记(二)
    本次主要内容如下:1,视图视图是虚表,不会真实存储数据,需要通过在创建视图的时候用SELECT语句创建。视图的好处:数据安全性,只开放必要的数据字段;提高数据使用效率,减少频率使用SELECT语句查询,直接通过视图可以查询;视图的创建:CREATEVIEWASSELECTXXXXFROMTABLE;视图的修改......