REGEXP_REPLACE(substr(b.real_value, 0, 6), '[^-.0-9]', '')用to_number
时间: 2024-10-27 10:02:09 浏览: 30
在SQL中,`REGEXP_REPLACE`函数通常用于替换字符串中满足正则表达式模式的部分。这里的一段示例:
```sql
REGEXP_REPLACE(substr(b.real_value, 0, 6), '[^-.0-9]', '')
```
这段代码的意思是从变量`b.real_value`的前六个字符开始,查找并替换所有不是数字、减号(`-`)或点(`.`)的字符。结果是一个只包含数字、减号和点的新字符串。
如果你想等效地用`TO_NUMBER`函数完成这个操作,你需要先尝试转换整个字符串,然后使用`TRIM`或`REPLACE`去掉不必要的字符。因为`TO_NUMBER`会在遇到非数字字符时停止转换,并返回到那时为止的结果。如果原始字符串全是合法数字,`TO_NUMBER`会直接返回数值。
下面是一个可能的转换示例:
```sql
CASE
WHEN TO_NUMBER(TRIM(BOTH '^-.' FROM b.real_value)) IS NOT NULL THEN TO_NUMBER(TRIM(BOTH '^-.' FROM b.real_value))
ELSE NULL
END
```
这段代码首先尝试去掉开头和结尾的负号或点,然后转换成数字,如果转换成功则返回数值,否则返回NULL。
相关问题
Oracle数据中的Regexp_*的大概用法(正则表达式)REGEXP_LIKE、REGEXP_INSTR 、REGEXP_SUBSTR 、REGEXP_REPLACE...
Oracle数据库中的Regexp_*函数系列是用于正则表达式操作的函数,下面是它们的大概用法:
1. REGEXP_LIKE:判断一个字符串是否符合正则表达式的模式。
语法:REGEXP_LIKE(string, pattern, match_parameter)
示例:SELECT '123' FROM DUAL WHERE REGEXP_LIKE('123', '^[0-9]+$');
2. REGEXP_INSTR:查找一个字符串中符合正则表达式模式的子串的起始位置。
语法:REGEXP_INSTR(string, pattern, position, occurrence, match_parameter)
示例:SELECT REGEXP_INSTR('hello world', 'world', 1, 1, 0) FROM DUAL;
3. REGEXP_SUBSTR:从一个字符串中提取符合正则表达式模式的子串。
语法:REGEXP_SUBSTR(string, pattern, position, occurrence, match_parameter)
示例:SELECT REGEXP_SUBSTR('hello world', '[a-z]+', 1, 1, 'i') FROM DUAL;
4. REGEXP_REPLACE:用一个新的字符串替换一个字符串中符合正则表达式模式的子串。
语法:REGEXP_REPLACE(string, pattern, replace_string, position, occurrence, match_parameter)
示例:SELECT REGEXP_REPLACE('hello world', '\b(\w+)\b', '[\1]', 1, 0, 'i') FROM DUAL;
其中,match_parameter 参数是用于指定匹配模式的参数,包括:
- i:大小写不敏感
- c:大小写敏感
- m:多行模式
- n:单行模式
- x:忽略空格和注释
这些函数可以非常方便地进行正则表达式的操作,提高了数据处理的灵活性和效率。
WITH TAB_B AS ( select DISTINCT A.calling_imsi as IMSI, coalesce(B.ANTIGUA,C.ANTIGUA) GJ, coalesce(B.APUA,C.APUA) YYS from ( SELECT A.calling_imsi, substr(a.calling_imsi,1,6) calling_imsi_6, substr(a.calling_imsi,1,5) calling_imsi_5, substr(a.calling_imsi,1,4) calling_imsi_4 FROM spark_odc_dwd.D_ENS_GBSSAP_CC a WHERE p_hour='#{time yyyyMMddHH}' ) a left join ( select SUBSTR(regexp_replace(IMSI,'[^0-9]+',''),1,6) IMSI_6, SUBSTR(regexp_replace(IMSI,'[^0-9]+',''),1,5) IMSI_5, ANTIGUA, APUA from spark_odc_data.A_DM_CO_BA_VR_OPT_IMSI )b on a.calling_imsi_6=b.IMSI_6 left join ( select SUBSTR(regexp_replace(IMSI,'[^0-9]+',''),1,6) IMSI_6, SUBSTR(regexp_replace(IMSI,'[^0-9]+',''),1,5) IMSI_5, ANTIGUA, APUA from spark_odc_data.A_DM_CO_BA_VR_OPT_IMSI )c on a.calling_imsi_5=c.IMSI_5)
这是一个SQL语句,它的作用是从表spark_odc_dwd.D_ENS_GBSSAP_CC中筛选出符合条件p_hour='#{time yyyyMMddHH}'的数据,并与表spark_odc_data.A_DM_CO_BA_VR_OPT_IMSI进行左连接,最终得到一个名为TAB_B的表,它包含IMSI、GJ和YYS三个字段。其中,IMSI字段来自表spark_odc_dwd.D_ENS_GBSSAP_CC中的calling_imsi字段,GJ和YYS字段则是通过左连接得到的。其中coalesce函数用于处理null值,如果B.ANTIGUA或C.ANTIGUA为空,则选择另一个不为空的值作为GJ字段的值;同理,如果B.APUA或C.APUA为空,则选择另一个不为空的值作为YYS字段的值。
阅读全文