oracle正则表达式存储过程冒泡

转载 2012年03月28日 20:41:37

Oracle 正则表达式函数-REGEXP_SUBSTR 使用例子2011-02-17 22:055个参数

第一个是输入的字符串

第二个是正则表达式

第三个是标识从第几个字符开始正则表达式匹配。(默认为1)

第四个是标识第几个匹配组。(默认为1)

第五个是是取值范围:

i:大小写不敏感;

c:大小写敏感;

n:点号 . 不匹配换行符号;

m:多行模式;

x:扩展模式,忽略正则表达式中的空白字符。

 

全部测试数据

SQL> select * from test_reg_substr;

A

-----------------------------------

ABC123XYZ

ABC123XYZ456

<Name>Edward</Name>

 

检索中间的数字

SQL> SELECT

 2    REGEXP_SUBSTR(a,'[0-9]+')

 3  FROM

 4    test_reg_substr

 5  WHERE

 6    REGEXP_LIKE(a, '[0-9]+');

REGEXP_SUBSTR(A,'[0-9]+')

---------------------------------

123

123

 

检索中间的数字(从第一个字母开始匹配,找第2个匹配项目)

SQL> SELECT

 2    NVL(REGEXP_SUBSTR(a,'[0-9]+',1, 2), '-') AS a

 3  FROM

 4    test_reg_substr

 5  WHERE

 6    REGEXP_LIKE(a, '[0-9]+');

A

------------------------------------------------------

-

456

 

取得“字符集合”

SQL> SELECT

 2    REGEXP_SUBSTR(a, '\w+')

 3  FROM

 4    test_reg_substr

  5  WHERE

 6    REGEXP_LIKE(a, '\w+');

REGEXP_SUBSTR(A,'\W+')

-------------------------------

ABC123XYZ

ABC123XYZ456

Name

 

取得“字符集合”(从第一个字母开始匹配,找第2个匹配项目)

SQL> SELECT

 2    NVL(REGEXP_SUBSTR(a, '\w+',1, 2), '-') AS a

 3  FROM

 4    test_reg_substr

  5  WHERE

 6    REGEXP_LIKE(a, '\w+');

 A

---------------------------------------------------

 -

-

Edward
----------------------------------------------------应用pr_bubble_Sort('12,343,435,434')
create or replace procedure pr_bubble_Sort(
                   in_arry in VARCHAR2
                                           )
IS        ------定义一个表数据,建立虚拟表,避免实表问题
           type one_arr is table of number
           index by binary_integer;
           my_one_arr one_arr;     
           n_cur_index number(6):=0;

           n_inner_index number(6):=0;
           n_temp number(6);
BEGIN
                  -----在oracle中使用正则表达式
   for i in (select regexp_substr(in_arry,'[^,]+',1,rownum) my_date
   from dual
   connect by rownum<= length(in_arry)
                                 - length(replace(in_arry,',',''))+1)
   LOOP
        ----------------开始循环体
         n_cur_index := n_cur_index +1;
         my_one_arr(n_cur_index) := i.my_date;
   end loop;
  
   if in_arry  is not null then
         n_inner_index := n_cur_index;
        
         for j in 1..n_cur_index
         loop
             n_inner_index := n_inner_index -1;
             for k in 1..n_inner_index
             loop
                if my_one_arr(k) > my_one_arr(k+1) then
                   n_temp := my_one_arr(k);
                   my_one_arr(k) := my_one_arr(k+1);
                   my_one_arr(k+1) := n_temp;
                end if;
             end loop;
         end loop;
        
         for l in 1..n_cur_index
         loop
             dbms_output.put_line(my_one_arr(l));
         end loop;  
  
   end if ;

end;

 

Oracle存储过程例子:运用了正则表达式、数组等

Oracle存储过程例子:运用了正则表达式、数组等 CREATE OR REPLACE PROCEDURE "SP_GET_ARTICLE_DATA" (article_det...
  • chuang123
  • chuang123
  • 2016年05月03日 18:28
  • 892

用Oracle实现冒泡排序

/*使用PL/SQL实现一个冒泡排序。 8个数:12 25 16 90 44 32 14 54 输出排序后的结果*/ declare         type mynumbe...
  • kyle0036
  • kyle0036
  • 2012年03月11日 01:55
  • 1036

oracle 冒泡排序法

教主弄的 SQL> with xo as 2 (select '4563531' as str from dual) 3 select listagg(substr(str,...
  • windsna
  • windsna
  • 2014年08月26日 17:50
  • 1220

oracle存储过程中单引号及字符串拼接处理

在ORACLE中,单引号有两个作用,一是字符串是由单引号引用,二是转义。单引号的使用是就近配对,即就近原则。而在单引号充当转义角色时相对不好理解 1、从第二个单引号开始被视为转义符,如果第二个单引号后...
  • Xiao_Bo_Ben
  • Xiao_Bo_Ben
  • 2013年09月09日 14:56
  • 5184

oracle 如何终止存储过程的运行

1. 在V$ACCESS视图中找到要停止进程的SID: 举例:存储过程名:CRH_ENTRY SELECT t.* FROM V$ACCESS t WHERE t.object='CRH_ENTRY'...
  • zengmingen
  • zengmingen
  • 2016年05月23日 15:50
  • 6121

Oracle PL/SQL如何动态调用存储过程

今天一同事问我Oracle PL/SQL如何动态调用存储过程,我觉得应该没有问题,刚试了一下OK,主要是用execute immediate 语法,注意using里指定in和out参数,具体测试示例如...
  • yzsind
  • yzsind
  • 2009年08月05日 19:51
  • 4341

oracle设置定时执行存储过程

oracle中可以使用dbms_job包来实现定时执行存储过程 其中主要使用的是: 1、新增定时任务:dbms_job.isubmit(jobid,what,next_date,interval,no...
  • lhjllff12345
  • lhjllff12345
  • 2016年02月23日 16:27
  • 5536

Oracle中执行存储过程call和exec区别

在sqlplus中这两种方法都可以使用:  exec pro_name(参数1..); call pro_name(参数1..);  区别:  1. 但是exec是sqlplus命令,只能在sqlpl...
  • zengmingen
  • zengmingen
  • 2016年05月10日 17:02
  • 18756

Oracle 存储过程之批量添加数据

–vc_trade_id 复制交易方案id –vc_new_trade_id 新id –vc_scheme_date 系统逻辑时间 –l_trade_stage 交易方案轮次 –vc_tr...
  • zhumuqxie
  • zhumuqxie
  • 2017年02月28日 15:25
  • 141

oracle存储过程if-else if-else

create or replace procedure test as --建立游标 Cursor ss is select GROUP_NAME from SUMMARYLOG_LIST gr...
  • aline200
  • aline200
  • 2015年09月14日 16:03
  • 3514
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle正则表达式存储过程冒泡
举报原因:
原因补充:

(最多只允许输入30个字)