热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

SQLSERVER2012中新增函数之字符串函数CONCAT详解

SQLServer2012有一个新函数,就是CONCAT函数,连接字符串非它莫属。比如在它出现之前,连接字符串是使用"+"来连接,如遇上NULL,还得设置参数与配置,不然连接出来的结果将会是一个NULL。本文就介绍了关于SQLSERVER2012中CONCAT函数的相关资料,需要的朋友可以参考。

介绍

SQLSERVER 2012新增了两个字符串函数CONCAT和FORMAT。本文首先介绍一下CONCAT,CONCAT函数的作用是可以返回多个字符串拼接后的结果。

CONCAT 函数最多可以连接255个字符变量,当调用这个函数的时候需要至少接收两个参数,参数类型不一定是字符串类型,也可以是可以隐式转换为字符串的类型比如int ,float等类型。只要符合sql 2012的能隐式转换为字符串的规则即可,当我们想把两个值类型的数据连接起来的时候,不需要先将它们转为nvarchar然后再通过“+”来连接了

简单示例:

select CONCAT('a','b') as R1 
/* 
R1 
---- 
ab 
*/ 
select 'a'+'b' as R2 
/* 
R2 
---- 
ab 
*/ 

如此看来这个函数似乎使SQL语句变得更长了,这个函数到底有什么优点呢?

下面我举个实例说明一下(数据就从百度随便搜了个排行榜)

if object_id('tb') is not null drop table tb 
create table tb([Rank] int,[Name] varchar(10),[SearchTime] int,[Remarks] varchar(10)) 
insert tb 
select 1,'完美世界',118251,'我没看过' unionall 
select 2,'莽荒纪',104532,'我没看过' unionall 
select 3,'大主宰',93453,'我没看过' unionall 
select 4,'绝世唐门',63333,'我没看过' unionall 
select 5,'最强弃少',38198,'我没看过' unionall 
select 6,'傲世九重天',31137,'我没看过' unionall 
select 7,'唐砖',29166,'我没看过' unionall 
select 8,'武极天下',26435,'我也没看过' unionall 
select 9,'魔天记',25227,'我都没看过' unionall 
select 10,'剑道独尊',25097,null 

针对以上数据,例如我们要得到如下结果:

第1名:完美世界 搜索指数:118251 备注:我没看过

也许我们会这样写:

select '第'+ltrim([Rank])+'名:'+[Name]+' 搜索指数:'+ltrim([SearchTime])+' 备注:'+isnull([Remarks],'') as R3 from tb 
/* 
R3 
-------------------------------------------------------------------- 
第1名:完美世界搜索指数:118251 备注:我没看过 
第2名:莽荒纪搜索指数:104532 备注:我没看过 
第3名:大主宰搜索指数:93453 备注:我没看过 
第4名:绝世唐门搜索指数:63333 备注:我没看过 
第5名:最强弃少搜索指数:38198 备注:我没看过 
第6名:傲世九重天搜索指数:31137 备注:我没看过 
第7名:唐砖搜索指数:29166 备注:我没看过 
第8名:武极天下搜索指数:26435 备注:我也没看过 
第9名:魔天记搜索指数:25227 备注:我都没看过 
第10名:剑道独尊搜索指数:25097 备注: 
*/ 

有了CONCAT以后,我们可以这样:

select concat('第',[Rank],'名:',[Name],' 搜索指数:',[SearchTime],' 备注:',[Remarks]) as R4 from tb 
/* 
R4 
--------------------------------------------------------------------- 
第1名:完美世界 搜索指数:118251 备注:我没看过 
第2名:莽荒纪 搜索指数:104532 备注:我没看过 
第3名:大主宰 搜索指数:93453 备注:我没看过 
第4名:绝世唐门 搜索指数:63333 备注:我没看过 
第5名:最强弃少 搜索指数:38198 备注:我没看过 
第6名:傲世九重天 搜索指数:31137 备注:我没看过 
第7名:唐砖 搜索指数:29166 备注:我没看过 
第8名:武极天下 搜索指数:26435 备注:我也没看过 
第9名:魔天记 搜索指数:25227 备注:我都没看过 
第10名:剑道独尊 搜索指数:25097 备注: 
*/ 

从上面的实例中我们可以看到CONCAT的两个优点:

      1.当数据类型不一致的时候可以自动转换;

      2.对于null的处理,不用isnull也可以避免因拼接而导致结果为null的情况。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


推荐阅读
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • 本文详细探讨了HTTP 500内部服务器错误的成因、解决方案及其在Web开发中的影响。通过对具体案例的分析,帮助读者理解并解决此类问题。 ... [详细]
  • 在维护公司项目时,发现按下手机的某个物理按键后会激活相应的服务,并在屏幕上模拟点击特定坐标点。本文详细介绍了如何使用ADB Shell Input命令来模拟各种输入事件,包括滑动、按键和点击等。 ... [详细]
  • 百度服务再次遭遇技术问题,疑似DNS解析故障
    近日晚间,百度多项在线服务出现加载异常,包括移动端搜索在内的多个功能受到影响。初步迹象表明,问题可能与DNS服务器解析有关。 ... [详细]
  • 自媒体创作必备工具与软件推荐
    本文将详细介绍自媒体创作者所需的各类工具和软件,包括视频制作、剪辑、发布平台管理等方面的专业建议。 ... [详细]
  • 探讨如何使用工具或方法来自定义百度网盘的提取码,以提高文件分享的安全性和便捷性。 ... [详细]
  • 摘要:为了解决下载速度慢的问题,本文介绍了一种高效的下载方法,并提供了详细的步骤和工具推荐。通过使用百度网盘分享功能,可以显著提高文件传输效率。 ... [详细]
  • 通过与阿里云的合作,牛客网成功解决了跨国视频面试中的网络卡顿问题,为求职者和面试官提供了更加流畅的沟通体验。 ... [详细]
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • 揭秘:为何我的网名是老紫竹
    本文详细解释了作者为何选择“老紫竹”作为网名,从个人喜好到网络经历,以及与紫竹植物的渊源。 ... [详细]
  • 本文将深入探讨PHP编程语言的基本概念,并解释PHP概念股的含义。通过详细解析,帮助读者理解PHP在Web开发和股票市场中的重要性。 ... [详细]
author-avatar
夏雨之唯美
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有