sql语句replace函数的使用

SQL中的替换函数replace()使用

语法
REPLACE ( string_expression , string_pattern , string_replacement )

参数
string_expression 要搜索的字符串表达式。string_expression 可以是字符或二进制数据类型。
string_pattern 是要查找的子字符串。string_pattern 可以是字符或二进制数据类型。string_pattern 不能是空字符串 (‘‘)。
string_replacement 替换字符串。string_replacement 可以是字符或二进制数据类型。

返回类型
如果其中的一个输入参数数据类型为 nvarchar,则返回 nvarchar;否则 REPLACE 返回 varchar。
如果任何一个参数为 NULL,则返回 NULL。

上面都是官话,不好懂!翻成白话:REPLACE(String,from_str,to_str) 即:将String中所有出现的from_str替换为to_str。

说明:接触这个参数是因为我要创建合同,分为草稿和提审状态,并且修改也不知道用户修改哪些字段,所以应用到了替换插入 relpace into
用法:用的时候在数据库建给某一个字段建一个唯一索引,保证数据的唯一性并能更改, 如果插入的时候只要索引相同 其他字段不同 都会更改,由此非常便利

一、准备实验环境

1.1 创建表:

CREATE TABLE test_tb (
id int(10) unsigned NOT NULL auto_increment COMMENT ‘主键自增‘,
name char(30) default NULL COMMENT ‘姓名‘,
address char(60) default NULL COMMENT ‘地址‘,
country char(200) default NULL COMMENT ‘国家‘,
PRIMARY KEY (id)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT=‘测试表‘

1.2 插入数据:

insert into test_tb(name,address,country) values
(‘zhangsan‘,‘北京 朝阳区‘,‘中国‘),
(‘lisi‘,‘上海 浦东区‘,‘中国‘),
(‘wangwu‘,‘郑州金水区‘,‘中国‘),
(‘zhaoliu‘,‘香港九龙‘,‘中国香港‘),
(‘Q7‘,‘加州牛肉‘,‘美国‘),
(‘wangba‘,‘新九州岛‘,‘日本‘)

二、查询替换

2.1 将address字段里的 “区” 替换为 “呕” 显示,如下

select *,replace(address,‘区‘,‘呕‘) AS rep
from test_tb

2.2 将address字段里的 “九” 替换为 “十” 显示,如下

select *,replace(address,‘九‘,‘十‘) AS rep
from test_tb
where id in (4,6)

总结:联想到前面有讲过 使用IF(expr1,expr2,expr3) 及 CASE...WHEN...THEN...END 可以实现查询结果的别名显示,
但区别是:这两者是将查询结果值做整体的别名显示,而replace则可以对查询结果的局部字符串做替换显示(输出)。

三、更新替换

3.1 将address字段里的 “东” 替换为 “西” ,如下

update test_tb set address=replace(address,‘东‘,‘西‘) where id=2

总结:对字段中局部字符串做更新替换。

四、插入替换

4.1 将id=6的name字段值改为wokou

replace into test_tb VALUES(6,‘wokou‘,‘新九州岛‘,‘日本‘)

总结:向表中“替换插入”一条数据,如果原表中没有id=6这条数据就作为新数据插入(相当于insert into作用);如果原表中有id=6这条数据就做替换(相当于update作用)。对于没有指定的字段以默认值插入。

原文地址:https://www.cnblogs.com/yuanfang0903/p/11577307.html

时间: 2024-11-04 08:07:16

sql语句replace函数的使用的相关文章

Sql Server REPLACE函数的使用;SQL中 patindex函数的用法

Sql Server REPLACE函数的使用 REPLACE用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式. 语法REPLACE ( ''string_replace1'' , ''string_replace2'' , ''string_replace3'' ) 参数''string_replace1'' 待搜索的字符串表达式.string_replace1 可以是字符数据或二进制数据. ''string_replace2'' 待查找的字符串表达式.string_re

SQL 语句常用函数

一.字符转换函数 1.ASCII()返回字符表达式最左端字符的ASCII 码值.在ASCII()函数中,纯数字的字符串可不用''括起来,但含其它字符的字符串必须用''括起来使用,否则会出错. 2.CHAR()将ASCII 码转换为字符.如果没有输入0 ~ 255 之间的ASCII 码值,CHAR() 返回NULL . 3.LOWER()和UPPER()LOWER()将字符串全部转为小写:UPPER()将字符串全部转为大写. 4.STR()把数值型数据转换为字符型数据.STR (<float_ex

厚溥教育1718部数据库连接作业答案,分装一个操作数据库而无需写SQL语句的函数

<?php header("Content-type:text/html;charset=utf8"); //PHP操作数据库的函数 function phpsql($dbconfig,$type,$field='',$data=array(),$condition=array(),$join=array()){ //判断存不存在数据库连接主机 if(!isset($dbconfig['host'])){ return "数据库连接主机不存在"; } //判断

SQL中replace函数

昨天做修改操作时用到了replace函数 --备份表 create table ac01_20150105 as select * from ac01; create table ac01_dy_20150105 as select * from ac01_dy; create table cjscrz_20150105 as select * from cjscrz; --更新基本信息 update ac01 t set t.yhmc = replace(t.yhmc,'95580','962

四、oracle基本sql语句和函数详解

一.oracle常用数据类型 一.  数据定义语言(ddl) 数据定义语言ddl(data definition language)用于改变数据库结构,包括创建.更改和删除数据库对象. 用于操纵表结构的数据定义语言命令有: create table alter table truncate table drop table eg. --创建tb_stu表数据结构 create table tb_stu( id number, name varchar2(20) );   --修改tb_stu表数

Oracle数据库入门——sql语句和函数详解

一.oracle常用数据类型 一.  数据定义语言(ddl) 数据定义语言ddl(data definition language)用于改变数据库结构,包括创建.更改和删除数据库对象. 用于操纵表结构的数据定义语言命令有: create table alter table truncate table drop table eg. --创建tb_stu表数据结构 create table tb_stu( id number, name varchar2(20) );   --修改tb_stu表数

一、oracle基本sql语句和函数详解

一. 数据定义语言(ddl) 数据定义语言ddl(data definition language)用于改变数据库结构,包括创建.更改和删除数据库对象. 用于操纵表结构的数据定义语言命令有: create table alter table truncate table drop table eg. --创建tb_stu表数据结构 create table tb_stu( id number, name varchar2(20) ); --修改tb_stu表数据结构,新增一列 alter tab

sql语句replace into的用法

sql replace into用法详细说明 REPLACE的运行与INSERT很相似.只有一点例外,假如表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除. 注意,除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用一个REPLACE语句没有意义.该 语句会与INSERT相同,因为没有索引被用于确定是否新行复制了其它的行. 所有列的值均取自在REPLACE语句中被指定的值.所有缺失的列被设置为各自的默认值,

Sql Server REPLACE函数的使用

REPLACE用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式. 语法REPLACE ( ''string_replace1'' , ''string_replace2'' , ''string_replace3'' ) 例子:把Tbl_descTem 表dImgThumUrl列,dImgPicUrl列的值中'\'替换成'/' update dbo.Tbl_descTem set dImgThumUrl=replace([dImgThumUrl],'\','/') ,dIm