oracle 字符连接函数 concat 与 || ?

oracle中使用concat,concat只能连接两个字符,而“||”可以连接多个字符。

-concat只能连接两个字符串,连接多个需要嵌套调用不方便

如下

用concat时:

①.sql>select concat(‘aa’,‘bb’) from test;
结果; aabb

②.sql>select concat(‘aa’,‘bb’,‘cc’) from test;

 0RA-00909:invalid number of arguments(无效字符) : 说明在oracle中只容许两个参数,但在mysql中可以拼接多个字符串;

 因此,用concat连接多个字符时,需要嵌套

 sql>select concat(concat('aa','bb'),'cc') from test;

   结果; aabbcc 
    
 用||时:

       sql>select 'aa'||'bb' from test

       结果; aabb

③但在MySQL中concat可以拼接多个字符串:

     select concat( id, name, sex) from studen;

甚至可以拼接其他字符;

    select concat( id, '"',name, '"',sex) from studen;

但是如果要每个字段都拼接的话要写多次,很麻烦,所以使用concat_ws()函数在mysql中:

select  contant_ws(',', id ,name,sex) from studen;

这样每个字段都有引号了;

但是需要注意:

concat(str,str2) 返回结果为连接产生的字符串,如果有任何一个参数为null, 则返回值为null;
concat_ws(separator,str,str2) 第一个参数制定分隔符,需要注意分隔符不能为null,如果为null,返回结果null.

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值