oracle mysql 拼接值遇到的坑及双竖线 || concat详解

目录
  • oracle mysql 拼接值遇到的坑 双竖线 || concat
    • ||
    • concat()
  • Oracle中的字段拼接 CONCAT和 ||
    • 在Oracle中,字符串拼接有两种方法,分别是CONCAT()函数和“||”拼接
    • 1、CONCAT() 函数拼接
    • 2、使用 “||” 进行字符串的拼接
  • 补充:mysql使用concat或||拼接字符串遇到的坑

oracle mysql 拼接值遇到的坑 双竖线 || concat

||

“||” 在oracle中是拼接值,但在mysql中是“或”的意思。

where name like '%' || 'Tony' || '%'

所以推荐使用concat()

concat()

但concat()也有坑。

mysql中,可以直接用concat拼接3个值,

concat( '%' , 'Tonny' , '%' )

oracle中,这样使用是错误的。因为oracle的concat只能拼接2个值,需要这样:

concat( '%' , concat('Tonny' , '%') )

Oracle中的字段拼接 CONCAT和 ||

在Oracle中,字符串拼接有两种方法,分别是CONCAT()函数和“||”拼接

1、CONCAT() 函数拼接

缺点:只支持两个字符串的拼接,超过两个会报错(报的错好像是缺失右括号)

//表中的两个字段拼接
select concat(t1.column_1,t1.column_2) from table t1;//任意一个字段与任意字符串拼接 (time是取的别名,记住:Oracle 取别名不要用as )
select concat('时间是: ',t1.column_2) time from table t1;
select concat(t1.column_1,' 单位:元') time from table t1;//超过两个字段,会报错(下面这样写会报错)
select concat(t1.column_1,t1.column_2,t1.column_3) from table t1;

在使用CONCAT() 函数进行字符串拼接时,如果拼接的字段(字符串)中有中文,可能会导致乱码,解决方法把拼接的字段(字符串)加上 to_char()即可:

//如果遇到乱码,加上to_char()
select concat(to_char(t1.column_1),to_char(t1.column_2)) time from table t1;

2、使用 “||” 进行字符串的拼接

使用“||”拼接,就不受限制了

//表中两个字符串拼接,取别名为time
select t1.column_1 || t1.column_2 time from table t1;//表中三个字符串拼接,取别名为time
//这里可以使用括号将几个要拼接的字段括起来,可读性会好点,好像加不加括号都不影响
select (t1.column_1 || t1.column_2 || t1.column_3) time from table t1;

用“||”拼接的好处,在做模糊查询时,可以利用这个

//这样可以动态进行模糊查询,field是动态值
select t1.* from table t1 where t1.name like '%' || field || '%';//如果对模糊查询更加细粒度,当然,也可以使用concat()进行模糊查询
select t1.* from table t1 where t1.name like concat('%',field);
select t1.* from table t1 where t1.name like concat(field,'%');

补充:mysql使用concat或||拼接字符串遇到的坑

业务需要,将几个字段拼接为一个字段进行查询,发现查完了全是空,后来在网上查询发现:
使用 || 或者concat拼接字符串,如果其中一个是null,就变成null
转为使用 concat_ws可以避免

到此这篇关于oracle mysql 拼接值遇到的坑及双竖线 || concat详解的文章就介绍到这了,更多相关oracle mysql 双竖线 || concat内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • oracle wm_concat 列转行 逗号分隔

    [sql] 复制代码 代码如下: create table wlbtest1( username varchar2(2), deptID number ); create table wlbtest2( deptName varchar2(10), deptID number ); insert into wlbtest1 values ('a', 1); insert into wlbtest1 values ('b', 1); insert into wlbtest1 values ('c'

  • oracle—SQL技巧之(二)WMSYS.WM_CONCAT函数实现多行记录用逗号拼接在一起

    需求: 目前接触BI系统,由于业务系统的交易记录有很多,常常有些主管需要看到所有的记录情况,但是又不想滚动,想一眼就可以看到所有的,于是就想到了字符串拼接的形式. 解决方案:使用Oracle自带的函数 WMSYS.WM_CONCAT,进行拼接. 函数限制:它的输出不能超过4000个字节. 为了不让SQL出错,又可以满足业务的需求,超过4000个字节的部分,使用"..." 实现SQL如下: 复制代码 代码如下: CREATE TABLE TMP_PRODUCT (PRODUCT_TYPE

  • Mybatis 中 Oracle 的拼接模糊查询及用法详解

    一.结论 这里先给大家看一下结论 Oracle 中,拼接模糊查询的正确写法 SELECT A.USER_ID, A.USER_NAME FROM USER A AND A.USER_NAME like concat(concat('%','w'),'%') 或者 AND A.USER_NAME like '%' || 'w' || '%' Mybatis 中,拼接模糊查询的正确写法 <select id="selectByName" resultMap="BaseRes

  • oracle合并列的函数wm_concat的使用详解

    oracle wm_concat(column)函数使我们经常会使用到的,下面就教您如何使用oracle wm_concat(column)函数实现字段合并,如果您对oracle wm_concat(column)函数使用方面感兴趣的话,不妨一看.shopping:-----------------------------------------u_id       goods            num------------------------------------------1  

  • oracle mysql 拼接值遇到的坑及双竖线 || concat详解

    目录 oracle mysql 拼接值遇到的坑 双竖线 || concat || concat() Oracle中的字段拼接 CONCAT和 || 在Oracle中,字符串拼接有两种方法,分别是CONCAT()函数和“||”拼接 1.CONCAT() 函数拼接 2.使用 “||” 进行字符串的拼接 补充:mysql使用concat或||拼接字符串遇到的坑 oracle mysql 拼接值遇到的坑 双竖线 || concat || “||” 在oracle中是拼接值,但在mysql中是“或”的意思

  • MySQL 5.7 zip版本(zip版)安装配置步骤详解

    前言:重装win10顺带整理文件,然而装个MySQL用了我一下午,真是不值,所以写这篇来帮助大家. 一.下载 https://dev.mysql.com/downloads/mysql/ 二.解压缩zip包 三.配置环境变量 (1)配置Path (2)修改mysql-default.ini配置文件 原先的: # These are commonly set, remove the # and set as required.# basedir = .....# datadir = .....#

  • Mysql注入中的outfile、dumpfile、load_file函数详解

    在利用sql注入漏洞后期,最常用的就是通过mysql的file系列函数来进行读取敏感文件或者写入webshell,其中比较常用的函数有以下三个 into dumpfile() into outfile() load_file() 我们本次的测试数据如下 读写文件函数调用的限制 因为涉及到在服务器上写入文件,所以上述函数能否成功执行受到参数 secure_file_priv 的影响.官方文档中的描述如下 翻译一下就是 其中当参数 secure_file_priv 为空时,对导入导出无限制 当值为一

  • MySQL 行锁和表锁的含义及区别详解

    一.前言 对于行锁和表锁的含义区别,在面试中应该是高频出现的,我们应该对MySQL中的锁有一个系统的认识,更详细的需要自行查阅资料,本篇为概括性的总结回答. MySQL常用引擎有MyISAM和InnoDB,而InnoDB是mysql默认的引擎.MyISAM不支持行锁,而InnoDB支持行锁和表锁. 相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制. MySQL大致可归纳为以下3种锁: 表级锁:开销小,加锁快:不会出现死锁:锁定粒度大,发生锁冲突的概率

  • MySQL高级特性——数据表分区的概念及机制详解

    MySQL 的分区的实现方式是对数据表进行一层包装,这意味着索引实际是基于每个分区定义的,而不是整张表.这个特性和 Oracle 是不同的,在 Oracle 中的索引和数据表可以使用更灵活和更复杂的方式进行分区.​ MySQL 的分区通过定义 PATITION BY 子句的条件来决定数据行所属分区的归属.在执行查询的时候,查询优化器会区分所在分区,这意味着查询不会检查全部分区,而仅仅是那些包含索要查询数据所在的分区.​ 分区的主要目的是对数据表进行大致形式的索引和聚集.这样可以减少数据表的过大范

  • Oracle 数据仓库ETL技术之多表插入语句的示例详解

    目录 创建示例表 无条件的 INSERT ALL 语句 有条件的 INSERT ALL 语句 有条件的 INSERT FIRST 语句 多表插入语句的限制 大家好!我是只谈技术不剪发的 Tony 老师. ETL(提取.转换.加载)是指从源系统中提取数据并将其放入数据仓库的过程.Oracle 数据库为 ETL 流程提供了丰富的功能,今天我们就给大家介绍一下 Oracle 多表插入语句,也就是INSERT ALL语句. 创建示例表 我们首先创建一个源数据表和三个目标表: CREATE TABLE s

  • MySQL通过触发器解决数据库中表的行数限制详解及实例

    MySQL通过触发器解决数据库中表的行数限制详解及实例 最近项目一个需求是对操作日志的数量限制为10万条,超过十万条便删除最旧的那一条,保存数据库中日志数量不超过10万. 当时我的第一想法是通过触发器来做,便在数据库中执行了如下的SQL: delimiter $ create trigger limitLog before insert on OperationLog for each row begin if (select count(*) from OperationLog) > 1000

  • mysql(5.6及以下)解析json的方法实例详解

    mysql(5.6及以下)解析json #json解析函数 DELIMITER $$ DROP FUNCTION IF EXISTS `json_extract_c`$$ CREATE FUNCTION `json_extract_c`( details TEXT, required_field VARCHAR (255) ) RETURNS TEXT CHARSET latin1 BEGIN SET details = SUBSTRING_INDEX(details, "{", -1

  • window环境配置Mysql 5.7.21 windowx64.zip免安装版教程详解

    1.从官网下载mysql-5.7.21-windowx64.zip mysql下载页面 2.解压到合适的位置(E:\mysql) 这名字是我改过的 3.配置环境变量,将E:\mysql\bin 添加到PATH中 4.在mysql目录下(E:\mysql) 创建 my.ini文件,内容如下: [mysql] # 设置mysql客户端默认字符集 default-character-set=utf8 [mysqld] #设置3306端口 port = 3306 # 设置mysql的安装目录 based

  • MySQL系列之redo log、undo log和binlog详解

    事务的实现 redo log保证事务的持久性,undo log用来帮助事务回滚及MVCC的功能. InnoDB存储引擎体系结构 redo log Write Ahead Log策略 事务提交时,先写重做日志再修改页:当由于发生宕机而导致数据丢失时,就可以通过重做日志来完成数据的恢复. InnoDB首先将重做日志信息先放到重做日志缓存 按一定频率刷新到重做日志文件 重做日志文件: 在默认情况,InnoDB存储引擎的数据目录下会有两个名为ib_logfile1和ib_logfile2的文件.每个In

随机推荐