MySQL拼接函数CONCAT的使用心得,OMG

新闻资讯 老翟笔记小编 2024-03-23 22:50:24 41 0

老翟笔记今日分享的是:MySQL拼接函数CONCAT的使用心得,OMG

| 1 | D刀锋之影 | 泰隆 | 6300 | | 2 | X迅捷斥候 | 提莫 | 6300 | | 3 | G光辉女郎 | 拉克丝 | 1350 | | 4 | F发条魔灵 | 奥莉安娜 | 6300 | | 5 | Z至高之拳 | 李青 | 6300 | | 6 | W无极剑圣 | 易 | 450 | | 7 | J疾风剑豪 | 亚索 | 450 | ±—±--------------±-------------±------+ 7 rows in set (0.00 sec) 我需要返回一列:英雄称号 - 英雄名称 的数据,这是就用到了concat函数,如下: SELECT CONCAT(hero_title,’ - ',hero_name) as full_name, price from LOL; mysql> SELECT CONCAT(hero_title,' - ',hero_name) as full_name, price from `LOL`;+------------------------------+-------+| full_name | price |+------------------------------+-------+| D刀锋之影 - 泰隆 | 6300 || X迅捷斥候 - 提莫 | 6300 || G光辉女郎 - 拉克丝 | 1350 || F发条魔灵 - 奥莉安娜 | 6300 || Z至高之拳 - 李青 | 6300 || W无极剑圣 - 易 | 450 || J疾风剑豪 - 亚索 | 450 |+------------------------------+-------+7 rows in set (0.00 sec) ```如果拼接的参数中有NULL,则返回NULL;如下:```SELECT CONCAT(hero_title,NULL,hero_name) as full_name, price from `LOL`; mysql> SELECT CONCAT(hero_title,‘NULL’,hero_name) as full_name, price from LOL; ±------------------------------±------+ | full_name | price | ±------------------------------±------+ | D刀锋之影NULL泰隆 | 6300 | | X迅捷斥候NULL提莫 | 6300 | | G光辉女郎NULL拉克丝 | 1350 | | F发条魔灵NULL奥莉安娜 | 6300 | | Z至高之拳NULL李青 | 6300 | | W无极剑圣NULL易 | 450 | | J疾风剑豪NULL亚索 | 450 | ±------------------------------±------+ 7 rows in set (0.00 sec) ![在这里插入图片描述](https://img-blog.csdnimg.cn/20201014182811451.jpg#pic_center)不好意思,上面是我弟弟写的,正确的如下: mysql> SELECT CONCAT(hero_title,NULL,hero_name) as full_name, price from LOL; ±----------±------+ | full_name | price | ±----------±------+ | NULL | 6300 | | NULL | 6300 | | NULL | 1350 | | NULL | 6300 | | NULL | 6300 | | NULL | 450 | | NULL | 450 | ±----------±------+ 7 rows in set (0.00 sec) []( )1-2、函数:concat\_ws(separator,str1,str2,…)-------------------------------------------------------------------------------------------------------CONCAT\_WS() 函数全称: CONCAT With Separator ,是CONCAT()的特殊形式。第一个参数(separator)是其它参数的分隔符。分隔符的位置在要连接的两个字符串之间。`分隔符可以是一个字符串,也可以是其它字段参数。`**需要注意的是:**`如果分隔符为 NULL,则结果为 NULL;但如果分隔符后面的参数为NULL,只会被直接忽略掉,而不会导致结果为NULL。`好了,我们依旧用上面的LOL表,连接各字段,以逗号分隔: select concat_ws(’,’,hero_title,hero_name,price) as full_name, price from LOL; mysql> select concat_ws(',',hero_title,hero_name,price) as full_name, price from `LOL`;+---------------------------------+-------+| full_name | price |+---------------------------------+-------+| D刀锋之影,泰隆,6300 | 6300 || X迅捷斥候,提莫,6300 | 6300 || G光辉女郎,拉克丝,1350 | 1350 || F发条魔灵,奥莉安娜,6300 | 6300 || Z至高之拳,李青,6300 | 6300 || W无极剑圣,易,450 | 450 || J疾风剑豪,亚索,450 | 450 |+---------------------------------+-------+7 rows in set (0.00 sec) ```分隔符后的拼接参数为NULL时,直接忽略,不会影响整体结果,如下:```select concat_ws(',',hero_title,NULL,hero_name) as full_name, price from `LOL`; mysql> select concat_ws(’,’,hero_title,NULL,hero_name) as full_name, price from LOL; ±---------------------------±------+ | full_name | price | ±---------------------------±------+ | D刀锋之影,泰隆 | 6300 | | X迅捷斥候,提莫 | 6300 | | G光辉女郎,拉克丝 | 1350 | | F发条魔灵,奥莉安娜 | 6300 | | Z至高之拳,李青 | 6300 | | W无极剑圣,易 | 450 | | J疾风剑豪,亚索 | 450 | ±---------------------------±------+ 7 rows in set (0.00 sec) 分隔符为NULL时,结果返回NULL,如下: select concat_ws(NULL,hero_title,hero_name,price) as full_name, price from LOL; mysql> select concat_ws(NULL,hero_title,hero_name,price) as full_name, price from `LOL`;+-----------+-------+| full_name | price |+-----------+-------+| NULL | 6300 || NULL | 6300 || NULL | 1350 || NULL | 6300 || NULL | 6300 || NULL | 450 || NULL | 450 |+-----------+-------+7 rows in set (0.00 sec) ```[]( )1-3、函数:group\_concat(expr)-----------------------------------------------------------------------------------------> **group\_concat ( \[DISTINCT\] 字段名 \[order by 排序字段 ASC/DESC\] \[Separator ‘分隔符’\] )**group\_concat函数通常用于有group by的查询语句,group\_concat一般包含在查询返回结果字段中。是不是group\_concat函数的公式看着还挺复杂的?我们一起看看,上方公式中 \[\] 括号是可选项,表示可用可不用;* 1.`[DISTINCT]`:对拼接的参数支持去重功能;* 2.`[Order by]`:拼接的参数支持排序功能;* 3.`[Separator]`:这个你很熟悉了,支持自定义’分隔符’,如不设置默认为无分隔符;好了,下面让我们来进入开心的测试环节吧~ 还是用这张LOL表,别问为什么。或许这就是青春吧!还记的那年通宵五排,大龙团的时候网吧停电了…![在这里插入图片描述](https://img-blog.csdnimg.cn/20201014183300758.gif#pic_center)又跑题了。。不好意思。```mysql> select * from `LOL`;+----+---------------+--------------+-------+| id | hero_title | hero_name | price |+----+---------------+--------------+-------+| 1 | D刀锋之影 | 泰隆 | 6300 || 2 | X迅捷斥候 | 提莫 | 6300 |# **总结**面试建议是,**一定要自信,敢于表达**,面试的时候我们对知识的掌握有时候很难面面俱到,把自己的思路说出来,而不是直接告诉面试官自己不懂,这也是可以加分的。以上就是蚂蚁技术四面和HR面试题目,**以下最新总结的最全**,范围包含最全MySQL、Spring、Redis、JVM等最全面试题和答案,仅用于参考![一份还热乎的蚂蚁金服面经(已拿Offer)面试流程4轮技术面+1轮HR](https://img-blog.csdnimg.cn/img_convert/8ca53c9ab48d4730691b12b0df0ef144.png)-----------+--------------+-------+| 1 | D刀锋之影 | 泰隆 | 6300 || 2 | X迅捷斥候 | 提莫 | 6300 |# **总结**面试建议是,**一定要自信,敢于表达**,面试的时候我们对知识的掌握有时候很难面面俱到,把自己的思路说出来,而不是直接告诉面试官自己不懂,这也是可以加分的。以上就是蚂蚁技术四面和HR面试题目,**以下最新总结的最全**,范围包含最全MySQL、Spring、Redis、JVM等最全面试题和答案,仅用于参考[外链图片转存中...(img-ePMQ21CU-1631066700801)]**[CodeChina开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频】](https://codechina.csdn.net/m0_60958482/java-p7)**

本文结束,感谢您的阅读和支持,希望以上内容能给你带来帮助。本文章来自网络,由老翟笔记小编团队整理发布。

  • 随机文章
  • 热门文章
  • 热评文章

评论区