Sql语言如何拼接数据?
在sql语言中对数据进行适当的操作,能够有效地减少查询出数据之后业务逻辑的代码量,因此本篇博文将介绍sql语言中的拼接数据的功能。
本文将介绍拼接字段、拼接列,以及在一定的限制下拼接同一字段中不同列数据的功能。Mysql和Sql Server在这项功能中各有不同,因此分开介绍。
以下图中的表格为例:
MySQL
1.符号 +
在MySQL中也支持使用加号拼接结果,但是它的运行结果与MySQL中的运行结果有所不同。在两个字段都是整型时,MySQL与Sql Server运行结果相同,都会返回两个整型值得和,但是在两个字段中有一个为字符串时,MySQL的返回结果不是拼接两字符串,而是默认字符串为零,再返回两个字段之和。
如上所示,因为Name字段不是整型,所以相当于Score1 + 0,所以返回值就是Score1的值,即90;另外,如果相加的两个字段全都是字符串,则返回0。
2.CONCAT
CONTACT的功能是直接将数据按照字符串格式拼接,类似于Sql Server中加号拼接字符串的功能。
在这里需要注意的是,CONCAT后面括号中的参数只要有一个值为null,整个函数的返回值就会为null。
3.CONCAT_WS
CONOCAT_WS的用法和前者类似,但是它的第一个参数为分隔符,在返回的值中,每一个参数之间都会有第一个参数作为分隔。
如果CONCAT_WS的第一个参数为null,则返回值为null,如果后面的参数中有null,则这些参数会被忽略,只返回其他参数和分隔符组成的字符串。
4.根据字段拼接 GROUP_CONTACT
在我们使用数据库时,会碰到这样一种情况:同一个Name的人有两条数据,但是他们的其他数据并不相同,而我们所需要的是同一个Name的人的Score1集合,即需要获得Name为A的所有的Score1并且希望将其拼接为一个字段,这里我们就需要用到GROUP_CONCAT。
函数语法如下:group_concat( 要连接的字段 ) [Order BY 排序字段 ASC/DESC] [Separator '分隔符']
其中GROUP BY 后面的字段是Name,所有同一排序字段的数据会被拼接后存入同一字段中,并以相应的分隔符分分隔。
如上的sql语句,返回值为:
因为上面的数据中只有Name为A和D的两项数据有重复,所有他们的Score1是拼接出来的。
值得注意的是GROUP_CONCAT是有长度限制的,MySQL对其的默认长度限制为1024,可以使用如下语句来进行修改长度: