本文实例讲述了MySQL中使用replace、regexp进行正则表达式替换的用法。分享给大家供大家参考,具体如下:

今天一个朋友问我,如果将数据库中查到的类似于“./uploads/110100_cityHotel_北京富豪华宾馆.jpg”这样的格式都修改为“./uploads/110100cityHotel北京富豪华宾馆.jpg”这样的格式。我本人是没有这样处理过数据的,但是我知道mysql是可以使用replace做到的,而且正则表达式也可以做到。

如何做呢?

我们只需要这样一条语句即可,

update master_data.md_employee set name=replace(name,"_",'') where id = 825;

-- 注replace(字段名,"需要替换的字符","替换的字符"),这样即可。

在Mysql中,replace和regexp主要是通过sql语句实现数据的替换。

我们先来说说replace 的具体用法。

mysql replace用法

1.replace into

replace into table (id,name) values('1′,'aa'),('2′,'bb')

此语句的作用是向表table中插入两条记录。如果主键id为1或2不存在

就相当于

insert into table (id,name) values('1′,'aa'),('2′,'bb')

如果存在相同的值则不会插入数据

2.replace(object,search,replace)

把object中出现search的全部替换为replace

select replace('www.jb51.net','w','Ww')

—>WwWwWw.jb51.net

例:把表table中的name字段中的aa替换为bb

update table set name=replace(name,'aa','bb')

由MySQL提供的模式匹配的其它类型是使用扩展正则表达式。

当你对这类模式进行匹配测试时,使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它们是同义词)。

扩展正则表达式的一些字符是:

· ‘.'匹配任何单个的字符。

· 字符类“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的范围,使用一个“-”。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。

· “ * ”匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配任何数量的数字,而“.*”匹配任何数量的任何字符。

如果REGEXP模式与被测试值的任何地方匹配,模式就匹配(这不同于LIKE模式匹配,只有与整个值匹配,模式才匹配)。

为了定位一个模式以便它必须匹配被测试值的开始或结尾,在模式开始处使用“^”或在模式的结尾用“$”。

为了说明扩展正则表达式如何工作,下面使用REGEXP重写上面所示的LIKE查询:

1.为了找出以“d”开头的名字,使用“^”匹配名字的开始:

SELECT * FROM master_data.md_employee WHERE name REGEXP '^d';

这样的结果集是不区分大小写的,如果你想强制使REGEXP比较区分大小写,使用BINARY关键字使其中一个字符串变为二进制字符串。该查询只匹配名称首字母的小写‘d'。

SELECT * FROM master_data.md_employee WHERE name REGEXP BINARY'^d';

为了找出以“love”结尾的名字,使用“$”匹配名字的结尾:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'love$';

为了找出包含一个“w”的名字,使用以下查询:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'w';

既然如果一个正则表达式出现在值的任何地方,其模式匹配了,就不必在先前的查询中在模式的两侧放置一个通配符以使得它匹配整个值,就像你使用了一个SQL模式那样。

为了找出包含正好5个字符的名字,使用“^”和“$”匹配名字的开始和结尾,和5个“.”实例在两者之间:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.....$';

你也可以使用“{n}”“重复n次”操作符重写前面的查询:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.{5}$';

这些知识一些简单的mysql的replace和regexp的用法,对于深入的学习,我们会在之后的文章会将具体的例子以及用法写出

PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:

希望本文所述对大家MySQL数据库计有所帮助。

js mysql替换_MySQL中使用replace、regexp进行正则表达式替换的用法分析相关推荐

  1. mysql正则替换_MySQL中使用replace、regexp进行正则表达式替换的用法分析

    本文实例讲述了MySQL中使用replace.regexp进行正则表达式替换的用法.分享给大家供大家参考,具体如下: 今天一个朋友问我,如果将数据库中查到的类似于"./uploads/110 ...

  2. mysql替换首字母_MySQL中使用replace、regexp进行正则表达式替换的用法分析

    这篇文章主要介绍了MySQL中使用replace.regexp进行正则表达式替换的用法,结合具体实例形式分析了replace.regexp正则替换的使用技巧与相关注意事项,需要的朋友可以参考下 本文实 ...

  3. mysql 正则替换 换行,MySQL中使用replace、regexp进行正则表达式替换的用法分析

    本文实例讲述了MySQL中使用replace.regexp进行正则表达式替换的用法.,具体如下: 今天一个朋友问我,如果将数据库中查到的类似于"./uploads/110100_cityHo ...

  4. mysql怎么把行名称替换_mysql中替换行首字符

    替换行首字符,而不替换字段中其它地方指定字符. UPDATE table SET open_time = CONCAT('W', open_time) WHERE open_time REGEXP ' ...

  5. mysql 互斥_MySql中互斥量mutex的实现

    数据库中的Mutex量指的是一种用于保护一些临界资源的使用的信号量.当有线程需要使用这些临界资源时,会请求获得mutex量,请求成功的线程进入临界区,而请求失败的线程只能等待它释放这个mutex.互斥 ...

  6. mysql 金额_Mysql中金额使用DECIMAL类型

    MySQL中存在float,double等非标准数据类型,也有decimal这种标准数据类型. 其区别在于,float,double等非标准类型,在DB中保存的是近似值,而Decimal则以字符串的形 ...

  7. mysql nvarchar用什么代替_mysql中char、varchar、nvarchar数据类型的用法区别

    mysql中char.varchar.nvarchar数据类型的用法区别 mysql中char.varchar.nvarchar数据类型的用法区别: 说明: 1.char: 固定长度的非 Unicod ...

  8. mysql 互斥_Mysql 中互斥锁的使用

    本文介绍如在在多线程mysql代码开发中使用互斥锁. mysql自己对c++的mutex又进行了一次封装,封装的代码可以在include/mysql/psi/mysql_thread.h  中找到. ...

  9. mysql left/right join算法效率分析_mysql left join,right join,inner join超详细用法分析

    MySQL left join,right join,inner join超详细用法分析 下面是例子分析 表A记录如下: aID        aNum 1           a20050111 2 ...

最新文章

  1. java三级考试_java web 学习 --第五天(Java三级考试)
  2. 为什么在iOS7中,UITableView顶部的UITableViewStyleGrouped样式具有额外的填充
  3. UnityShader入门精要-3.3 UnityShader的结构
  4. Jupyter不要自动启动浏览器(Firefox)
  5. Hive的安装-Hive的交互方式
  6. luogu P2216 [HAOI2007]理想的正方形 递推+ST表
  7. IOS8模拟器设置中文输入
  8. java 盘符 系统_JAVA小白预备内容
  9. 厉害了!如何在 Gihub 快速搜索开源项目?
  10. 站在2018看单片机和嵌入式芯片方案选型和发展趋势
  11. HDU6184 Counting Stars(三元环计数)
  12. 基于数据kmeans_data分析聚类画图 使用sc轮廓系数作为评价指标
  13. 互联网装修O2O模式是否可行?
  14. MIT Mini Cheetah–开源代码仿真环境搭建记录(Ubuntu20.04)
  15. 01-CSS属性:字体属性和文本属性
  16. 个推里群推php教程,GitHub - lyx2297999137/yii2-igetui: yii2个推
  17. 西方科学家依然对互联网的进化表示质疑
  18. 苹果 IAP 支付服务端处理完整流程及注意事项(包含订阅商品处理)
  19. java js方法_JAVA调用js方法
  20. gensim Word2Vec 训练和使用

热门文章

  1. 从zookeeper的下载安装到环境配置,轻松入门zookeeper!
  2. 网易云发送短信验证码java实现
  3. 【ABAQUS】模态分析
  4. 否定之否定规律之重回编程之路
  5. 【Python从零到壹】input()函数
  6. 游戏运维编年史|可能是目前最详细的游戏运维指南(转载附链接)
  7. 什么将成为云计算的基础设施
  8. 科学计算机怎么求方程,卡西欧科学计算器fx-82ES PLUS A怎么求解行列式和解多元一次方程?...
  9. mysql使用新建用户的好处_入门MySQL——用户与权限
  10. java虚拟机收集器_Java虚拟机(JVM)垃圾回收器G1收集器 - Break易站