mysql 中用正则表达式如何取一个字符串中指定的字段,

作者&投稿:泣曲 (若有异议请与网页底部的电邮联系)
mysql 正则表达式 如何截取字符串中指定格式的字符~

mysql> select @col;
+---------------------------+
| @col |
+---------------------------+
| 2.1.3.14单独的3中文3中文1 |
+---------------------------+
1 row in set

mysql> select concat(substring_index(@col, ".", 3), ".", replace(@col, concat(substring_index(@col, ".", 3), "."), "")+0) as result;
+----------+
| result |
+----------+
| 2.1.3.14 |
+----------+
1 row in set


你把第二句中的 @col 替换成你的列名就可以了,然后加上 from 表 成为一个完成的 sql 语句试试吧。

用不了正则表达式,只能用其他方式。最好的方式你还是用程序处理吧!

substring_index(input,split,index):input为要截取的字符,split为分隔符,Index为要截取第index个分隔符左(index为正)或右(index为负)的字符串。

举例:

'Provider="RiskManagement" finalScore="65" RGID="100397278"'     //获取finalScore的值

1、获取finalScore右边的字符

select substring_index('Provider="RiskManagement" finalScore="65" RGID="100397278"','finalScore="',-1);

2、再获取" RGID="左边的字符

select substring_index(substring_index('Provider="RiskManagement" finalScore="65" RGID="100397278"','finalScore="',-1),'" RGID="',1);

扩展资料

MySQL 字符串截取函数:left(), right(), substring(), substring_index()。还有 mid(), substr()。其中,mid(), substr() 等价于 substring() 函数,substring() 的功能非常强大和灵活。

1、字符串截取:left(str, length)

mysql> select left('sqlstudy.com', 3); 

| left('sqlstudy.com', 3) | 

| sql | 

2、字符串截取:right(str, length)

mysql> select right('sqlstudy.com', 3); 

| right('sqlstudy.com', 3) | 

| com | 



  代码如下:
  CREATE PROCEDURE sp_str
  (
  IN p_str VARCHAR(50), /*原始字符串*/
  IN p_begin_str VARCHAR(50), /*要匹配的起始字符串*/
  IN p_end_str VARCHAR(50)) /*要匹配的结束字符串*/
  OUT p_result VARCHAR(50)) /*返回结果*/
  NOT DETERMINISTIC
  SQL SECURITY DEFINER
  COMMENT ''
  BEGIN
  DECLARE m_len INT DEFAULT 0;
  DECLARE m_index INT DEFAULT 0;
  /*计算第一个匹配字符串的索引位置*/
  select locate(p_begin_str,p_str)+char_length(p_begin_str) into m_index;
  /*计算第一个匹配字符串的长度*/
  select locate(p_end_str,p_str,m_index) into m_len;
  select SUBSTRING(p_str,m_index,m_len-m_index) INTO p_result ;
  END;

  执行:
  CALL sp_str('[]abcd[12345]aa[]ss','abcd[',']',@result);
  返回值 @result 为12345
  call sp_str('[]abcd[sdww]aa[]ss','abcd[',']',@result);
  返回值 @result 为sdww
  如果不用存储过程,可以直接写sql语句实现:

  代码如下:
  select SUBSTRING(
  ']abcd[12345]111[]',
  locate('abcd[',']abcd[12345]111[]')+CHAR_LENGTH('abcd['),
  locate(']',']abcd[12345]111[]',CHAR_LENGTH('abcd['))-
  (select locate('abcd[',']abcd[12345]111[]')+CHAR_LENGTH('abcd['))
  )

  返回值为 12345
  关于mysql的函数介绍:
  CHAR_LENGTH(str)
  返回字符串str的长度。
  LOCATE(substr,str)
  POSITION(substr IN str)
  返回子串substr在字符串str第一个出现的位置,如果substr不是在str里面,返回0.
  mysql> select LOCATE('bar', 'foobarbar');
  -> 4
  mysql> select LOCATE('xbar', 'foobar');
  -> 0
  该函数是多字节可靠的。 LOCATE(substr,str,pos)
  返回子串substr在字符串str第一个出现的位置,从位置pos开始。如果substr不是在str里面,返回0。
  mysql> select LOCATE('bar', 'foobarbar',5);
  -> 7
  这函数是多字节可靠的。
  SUBSTRING(str,pos,len)
  SUBSTRING(str FROM pos FOR len)
  MID(str,pos,len)
  从字符串str返回一个len个字符的子串,从位置pos开始。使用FROM的变种形式是ANSI SQL92语法。
  mysql> select SUBSTRING('Quadratically',5,6);
  -> 'ratica'
  该函数是多字节可靠的。
  SUBSTRING(str,pos)

MySQL 一直以来都支持正则匹配,不过对于正则替换则一直到MySQL 8.0 才支持。对于这类场景,以前要么在MySQL端处理,要么把数据拿出来在应用端处理。

比如我想把表y1的列str1的出现第3个action的子 串替换成dble,怎么实现?


1. 自己写SQL层的存储函数。代码如下写死了3个,没有优化,仅仅作为演示,MySQL 里非常不建议写这样的函数。

  • mysql

  • DELIMITER $$

  • USE `ytt`$$

  • DROP FUNCTION IF EXISTS `func_instr_simple_ytt`$$

  • CREATE DEFINER=`root`@`localhost` FUNCTION `func_instr_simple_ytt`(

  • f_str VARCHAR(1000), -- Parameter 1

  • f_substr VARCHAR(100),  -- Parameter 2

  • f_replace_str varchar(100),

  • f_times int -- times counter.only support  3.

  • ) RETURNS varchar(1000)

  • BEGIN

  • declare v_result varchar(1000) default 'ytt'; -- result.

  • declare v_substr_len int default 0; -- search string length.

  • set f_times = 3; -- only support  3.

  • set v_substr_len = length(f_substr);

  • select instr(f_str,f_substr) into @p1; -- First real position .

  • select instr(substr(f_str,@p1+v_substr_len),f_substr) into @p2; Secondary virtual position.

  • select instr(substr(f_str,@p2+ @p1 +2*v_substr_len - 1),f_substr) into @p3; -- Third virtual position.

  • if @p1 > 0  && @p2 > 0 && @p3 > 0 then -- Fine.

  • select

  • concat(substr(f_str,1,@p1 + @p2 + @p3 + (f_times - 1) * v_substr_len  - f_times)

  • ,f_replace_str,

  • substr(f_str,@p1 + @p2 + @p3 + f_times * v_substr_len-2)) into v_result;

  • else

  • set v_result = f_str; -- Never changed.

  • end if;

  • -- Purge all session variables.

  • set @p1 = null;

  • set @p2 = null;

  • set @p3 = null;

  • return v_result;

  • end;

  • $$

  • DELIMITER ;

  • -- 调用函数来更新:

  • mysql> update y1 set str1 = func_instr_simple_ytt(str1,'action','dble',3);

  • Query OK, 20 rows affected (0.12 sec)

  • Rows matched: 20  Changed: 20  Warnings: 0

  • 2. 导出来用sed之类的工具替换掉在导入,步骤如下:(推荐使用)

    1)导出表y1的记录。

  • mysqlmysql> select * from y1 into outfile '/var/lib/mysql-files/y1.csv';Query OK, 20 rows affected (0.00 sec)


  • 2)用sed替换导出来的数据。

  • shellroot@ytt-Aspire-V5-471G:/var/lib/mysql-files#  sed -i 's/action/dble/3' y1.csv


  • 3)再次导入处理好的数据,完成。

  • mysql

  • mysql> truncate y1;

  • Query OK, 0 rows affected (0.99 sec)

  • mysql> load data infile '/var/lib/mysql-files/y1.csv' into table y1;

  • Query OK, 20 rows affected (0.14 sec)

  • Records: 20  Deleted: 0  Skipped: 0  Warnings: 0

  • 以上两种还是推荐导出来处理好了再重新导入,性能来的高些,而且还不用自己费劲写函数代码。

    那MySQL 8.0 对于以上的场景实现就非常简单了,一个函数就搞定了。

  • mysqlmysql> update y1 set str1 = regexp_replace(str1,'action','dble',1,3) ;Query OK, 20 rows affected (0.13 sec)Rows matched: 20  Changed: 20  Warnings: 0


  • 还有一个regexp_instr 也非常有用,特别是这种特指出现第几次的场景。比如定义 SESSION 变量@a。

  • mysqlmysql> set @a = 'aa bb cc ee fi lucy  1 1 1 b s 2 3 4 5 2 3 5 561 19 10 10 20 30 10 40';Query OK, 0 rows affected (0.04 sec)


  • 拿到至少两次的数字出现的第二次子串的位置。

  • mysqlmysql> select regexp_instr(@a,'[:digit:]{2,}',1,2);+--------------------------------------+| regexp_instr(@a,'[:digit:]{2,}',1,2) |+--------------------------------------+|                                   50 |+--------------------------------------+1 row in set (0.00 sec)


  • 那我们在看看对多字节字符支持如何。

  • mysql

  • mysql> set @a = '中国 美国 俄罗斯 日本 中国 北京 上海 深圳 广州 北京 上海 武汉 东莞 北京 青岛 北京';

  • Query OK, 0 rows affected (0.00 sec)

  • mysql> select regexp_instr(@a,'北京',1,1);

  • +-------------------------------+

  • | regexp_instr(@a,'北京',1,1)   |

  • +-------------------------------+

  • |                            17 |

  • +-------------------------------+

  • 1 row in set (0.00 sec)

  • mysql> select regexp_instr(@a,'北京',1,2);

  • +-------------------------------+

  • | regexp_instr(@a,'北京',1,2)   |

  • +-------------------------------+

  • |                            29 |

  • +-------------------------------+

  • 1 row in set (0.00 sec)

  • mysql> select regexp_instr(@a,'北京',1,3);

  • +-------------------------------+

  • | regexp_instr(@a,'北京',1,3)   |

  • +-------------------------------+

  • |                            41 |

  • +-------------------------------+

  • 1 row in set (0.00 sec)

  • 那总结下,这里我提到了 MySQL 8.0 的两个最有用的正则匹配函数 regexp_replace 和 regexp_instr。针对以前类似的场景算是有一个完美的解决方案。



set @str := '{"brightness_current":0,"profile_currunt":1}';
set @find_str := '"brightness_current":';
select @find_str, value from (select @start_pos := locate(@find_str, @str), @end_pos := @start_pos + length(@find_str), @tail_pos := if(locate(",", @str, @end_pos) = 0, locate("}", @str, @end_pos), locate(",", @str, @end_pos)), substring(@str, @end_pos, @tail_pos - @end_pos) as value) as t;
输出:
+-----------------------+-------+
| @find_str | value |
+-----------------------+-------+
| "brightness_current": | 0 |
+-----------------------+-------+
1 row in set (0.01 sec)

set @str := '{"brightness_current":0,"profile_currunt":1}';
set @find_str := '"profile_currunt":';
select @find_str, value from (select @start_pos := locate(@find_str, @str), @end_pos := @start_pos + length(@find_str), @tail_pos := if(locate(",", @str, @end_pos) = 0, locate("}", @str, @end_pos), locate(",", @str, @end_pos)), substring(@str, @end_pos, @tail_pos - @end_pos) as value) as t;
输出:
+--------------------+-------+
| @find_str | value |
+--------------------+-------+
| "profile_currunt": | 1 |
+--------------------+-------+
1 row in set (0.01 sec)

确定是在mysql环境及SQL下用正则解析吗?你贴的这是标准的JSON字符流啊、在应用层解析会更好啊。否则你干脆substr还直接些。


鄂尔多斯市15132562389: mysql 中用正则表达式如何取一个字符串中指定的字段, -
辛甘灯盏: 代码如下:CREATE PROCEDURE sp_str(IN p_str VARCHAR(50), /*原始字符串*/IN p_begin_str VARCHAR(50), /*要匹配的起始字符串*/IN p_end_str VARCHAR(50)) /*要匹配的结束字符串*/OUT p_result VARCHAR(50)) /*返回结果*/...

鄂尔多斯市15132562389: 如何用正则表达式截取字符串中的某一段? -
辛甘灯盏: 表达式用:name:(.*)[\r\n]habit:(.*) 截取用:\1 \2 由于你没有说明你所使用的正则表达式语法/拓展.回答默认支持\r\n拓展.如有需要请自行替换.

鄂尔多斯市15132562389: 正则表达式 如何取出指定字符的字符串 只唯一包含的 -
辛甘灯盏: 下面的正则是可行的: (?<=^|\n)(([^hl\n])|(h(?!l))|((?!h)l))*hl(([^hl\n])|(h(?!l))|((?!h)l))*(?=\r|$) 用正则工具测了下,引擎是Python,结果是你想要的.注意这个正则把多行正则看作一个串(即把回车\r和换行\n当作一般字符匹配,而不是分行). 有问题交流啊

鄂尔多斯市15132562389: 如何在sql语句中使用正则表达式 -
辛甘灯盏: sqlserver中,主要有regexp_like,regexp_replace,regexp_substr,regexp_instr四个正则表达式函数.1、regexp_like:regexp_like(x,pattern[,match_option]),查看x是否与pattern相匹配,该函数还可以提供一个可选的参数match_option字符串说明默...

鄂尔多斯市15132562389: mysql正则表达式替换字符串 -
辛甘灯盏: mysql的正则匹配用regexp,而替换字符串用REPLACE(str,from_str,to_str) 举例如下: UPDATE myTable SET HTML=REPLACE(HTML,'<br>','') WHERE HTML REGEXP '(<br */*>\s*){2,}' 达到的效果:会把所有<br>全部替换掉. mysql中常用的...

鄂尔多斯市15132562389: 在ms sql中如何使用正则表达式,请给出简单示例,注释越详细越好!感激不尽 -
辛甘灯盏: MS SQL不支持正则表达式,可以用CLR实现.1、 新建一个 MSSQL的数据库项目,配置到你的数据库中2、 在数据库项目中新建一个函数库,编写如下代码: /// <summary> /// 验证是否符合正则表达式 /// </summary> [SqlFunction] public static ...

鄂尔多斯市15132562389: 正则表达式获取sql中的数据库名 -
辛甘灯盏: 不知道你用的什么语言:以下为Java String str = "USE TEST";//标准 String str2 = "USE [test]";//加[] String str3 = "use [TEST];";//小写 +[] + ; System.out.println(str.replaceAll("(?i)use\\s+","").replaceAll("[\\[\\];]","")); System....

鄂尔多斯市15132562389: mysql中如何写 用正则表达式验证11位手机号 -
辛甘灯盏: 12345 if(preg_match("/^1[34578]{1}\d{9}$/",$tel)){ echo'符合'; }else{ echo'不符合'; }

鄂尔多斯市15132562389: sql语句 怎么用 正则表达式 查询 一个 符合 “ - ” 加数字 的字短? 如查出 字段 “ - 23", 而 “ - 23 - ” -
辛甘灯盏: select * from tba where b like '-[0-9]'or b like '-[0-9][0-9]' or b like '-[0-9]%[0-9]'-------------------------------- select * from abc where b like '-[0-9]'or -----------匹配:'-'加单数字 b like '-[0-9][0-9]' or ------匹配:'-'加双数字 b like '-[0-9]%[0-9]' -------匹配:'-'加三个以上数字

鄂尔多斯市15132562389: mysql数据库中 正则表达式 “{n,m}”的用法? -
辛甘灯盏: {n,m} 表示,前面的字符至少匹配n次,最多匹配m次 用php preg_match()函数举例$str = 'goooogle'; if(preg_match("/go{1,3}gle/",$str)) echo '匹配'; else echo '不匹配'; //g*gle 其中的*号只能在1-3个o时能匹配 ?>

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网