热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql中replace函数的用法_MySQL

mysql中replace函数的用法
mysql中replace函数的用法_MySQL

##-----MySQL数据替换即replace的运用-----##
#这里主要介绍一些关于replace函数的用法。关于研究这个主要是发现replace功能很强大
#对于屏蔽关键字很有用处。
#现在继续在以前的数据表中进行相关操作。
示例数据表:

mysql> select * from mytable;
+----+--------+-------+
| id | name | count |
+----+--------+-------+
| 1 | 张三 | 1000 |
| 2 | 李四 | 500 |
| 3 | 王老虎 | 100 |
| 4 | 赵大 | 1000 |
| 5 | 王二小 | 500 |
| 6 | 三亚子 | 100 |
| 7 | ?阿琼 | 1000 |
| 8 | 秋水虾 | 500 |
| 22 | 害人精 | 100 |
+----+--------+-------+
9 rows in set (0.00 sec)
#这里有9条原始数据,下面用replace进行数据的替换:
#update mytable set name=replace(name,'害人精','马屁精');

mysql> update mytable set name=replace(name,'张三','阿琼');
Query OK, 1 row affected (0.06 sec)
Rows matched: 9 Changed: 1 Warnings: 0
+----+--------+-------+
| id | name | count |
+----+--------+-------+
| 1 | 阿琼 | 1000 |
| 2 | 李四 | 500 |

#为了更加清晰的了解replace替换的方式,这里我们让其替换多个数据:
#update mytable set name=replace(name,'三','大炮');
#由于数据被更改过,里面只有一个’三‘,这里再添加几条数据:
#insert into mytable(name,count) values ('三毛子','200');
#insert into mytable(name,count) values ('张三胖','250');

mysql> insert into mytable(name,count) values ('三毛子','200');
Query OK, 1 row affected (0.00 sec)

mysql> insert into mytable(name,count) values ('张三胖','250');
Query OK, 1 row affected (0.00 sec)

#现在进行替换:
mysql> update mytable set name=replace(name,'三','大炮');
Query OK, 3 rows affected (0.00 sec) #这里显示改变了三条数据,找数据表中有3天带'三'数据
Rows matched: 11 Changed: 3 Warnings: 0

#结果:
| 6 | 大炮亚子 | 100 |
| 7 | ?阿琼 | 1000 |
| 8 | 秋水虾 | 500 |
| 22 | 马屁精 | 100 |
| 23 | 大炮毛子 | 200 |
| 24 | 张大炮胖 | 250 |
+----+----------+-------+
11 rows in set (0.00 sec)

##多条数据替换
#一开始以为这是个错误的sql语句:
#update mytable set name=replace(name,'马屁精','小马哥'),name=replace(name,'小李子','李子');

mysql> update mytable set name=replace(name,'马屁精','小马哥'),name=replace(name
,'小李子','李子');
Query OK, 2 rows affected (0.00 sec)
Rows matched: 11 Changed: 2 Warnings: 0
#从结果来看,如果进行多组数据的替换可以使用上面的方式。

#接下来进行各个字段的替换:
#update mytable set name=replace(name,'秋水虾','吐丝草'),count=replace(count,100,300);

mysql> update mytable set name=replace(name,'秋水虾','吐丝草'),count=replace(cou
nt,100,300);
Query OK, 7 rows affected (0.00 sec) #影响了7个结果,这确实出乎意料,按照我的预测应该
Rows matched: 11 Changed: 7 Warnings: 0 #为1+3=4个影响结果

#下面我们看看数据是如何变化的:
+----+----------+-------+
| id | name | count |
+----+----------+-------+
| 1 | 阿琼 | 3000 | #1000变为3000也就是说将前三位改变了。
| 2 | 李子 | 500 |
| 3 | 王老虎 | 300 | #100变为300,正常变化
| 4 | 赵大 | 3000 |
| 5 | 王二小 | 500 |
| 6 | 大炮亚子 | 300 |
| 7 | ?阿琼 | 3000 |
| 8 | 吐丝草 | 500 |
| 22 | 小马哥 | 300 |
| 23 | 大炮毛子 | 200 |
| 24 | 张大炮胖 | 250 |
+----+----------+-------+
11 rows in set (0.00 sec)

#对于这样的结果只能看作是在replace中所有的数据都是字符串。(仅个人认为)
#update mytable set name=replace(name,王二小,王铁柱); #该方式无法通过
#update mytable set count=replace(count,'500','100');

mysql> update mytable set count=replace(count,'500','100');
Query OK, 3 rows affected (0.00 sec) #确实为预期结果
Rows matched: 11 Changed: 3 Warnings: 0

#为此,数据在replace中仅仅是字符串
mysql> update mytable set count=replace(count,'300','150');
Query OK, 6 rows affected (0.00 sec) #结果再次得以证明
Rows matched: 11 Changed: 6 Warnings: 0

##综上,replace可以用于一个字段的多个数据替换,也可以用于不同字段的替换。
#在mysql中replace可以在一定范围内起到insert的作用,并且语法与之相似

#replace into mytable(name,count) values ('来福','70'),('力拓','600');
mysql> replace into mytable(name,count) values ('来福','70'),('力拓','600');
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0 Warnings: 0

#如果数据库中有类似数据又该如何呢?
replace into mytable(name,count) values ('来福','70');
mysql> replace into mytable(name,count) values ('来福','70');
Query OK, 1 row affected (0.00 sec)

#这里我们查看一下该表的索引,看来索引为默认的ID.
mysql> show index from mytable;
+---------+------------+----------+--------------+-------------+-----------+----
---------+----------+--------+------+------------+---------+
| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Car
dinality | Sub_part | Packed | Null | Index_type | Comment |
+---------+------------+----------+--------------+-------------+-----------+----
---------+----------+--------+------+------------+---------+
| mytable | 0 | PRIMARY | 1 | id | A |
14 | NULL | NULL | | BTREE | |
+---------+------------+----------+--------------+-------------+-----------+----
---------+----------+--------+------+------------+---------+
1 row in set (0.00 sec)

#根据文档介绍,如果只有一个索引,那么replace相当于insert.
##记得我曾经创建了两个表,现在我们切换到另一个数据较少的表mytab上进行操作演示:
mysql> show tables;
+----------------+
| Tables_in_mydb |
+----------------+
| mytab |
| mytable |
+----------------+
2 rows in set (0.00 sec)
#其默认的索引为id
mysql> show index from mytab;
+-------+------------+----------+--------------+-------------+-----------+------
-------+----------+--------+------+------------+---------+
| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardi
nality | Sub_part | Packed | Null | Index_type | Comment |
+-------+------------+----------+--------------+-------------+-----------+------
-------+----------+--------+------+------------+---------+
| mytab | 0 | PRIMARY | 1 | id | A |
3 | NULL | NULL | | BTREE | |
+-------+------------+----------+--------------+-------------+-----------+------
-------+----------+--------+------+------------+---------+
1 row in set (0.00 sec)

#现在需要向其中添加索引(在这里遇到麻烦了,看来我对于建立索引不怎么会啊,惭愧惭愧)。
#尝试建立了多个索引都是失败,暂时写到这里。。。。
写这些并非上班不务正业,而是公司具体任务被安排到下周,接下来该忙了。

以上就是mysql中replace函数的用法_MySQL的内容,更多相关内容请关注PHP中文网(www.php1.cn)!

推荐阅读
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • PHP中Smarty模板引擎自定义函数详解
    本文详细介绍了如何在PHP的Smarty模板引擎中自定义函数,并通过具体示例演示了这些函数的使用方法和应用场景。适合PHP后端开发者学习。 ... [详细]
  • 解决ADODB连接Access时出现80004005错误的方法
    本文详细介绍了如何解决在使用ADODB连接Access数据库时遇到的80004005错误,包括错误原因分析和具体的解决步骤。 ... [详细]
  • 本文详细解析了MySQL中常见的几种错误,并提供了具体的解决方法,帮助开发者快速定位和解决问题。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本文介绍了MySQL窗口函数的基本概念、应用场景及常见函数的使用方法。窗口函数在处理复杂查询时非常有用,例如计算每个用户的订单排名、环比增长率、以及动态聚合等。 ... [详细]
  • 本文介绍了如何在 Oracle 数据库中查询重复数据,并提供了多种方法来筛选和删除重复记录,包括基于单个字段和多个字段的重复数据处理。 ... [详细]
  • 本文提供了处理WordPress网站中出现过多重定向问题的方法,包括检查DNS配置、安装SSL证书以及解决数据库连接错误等步骤。 ... [详细]
  • 最适合初学者的编程语言
    本文探讨了适合编程新手的最佳语言选择,包括Python、JavaScript等易于上手且功能强大的语言,以及如何通过有效的学习方法提高编程技能。 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
author-avatar
用户7krcbz6eb6
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有