电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

mysql字符串拼接的4種方式總結

瀏覽:268日期:2023-02-18 16:43:29
目錄
  • 前言
  • 第一種:
  • 第二種:
  • 第三種:
  • 第四種(運算,只對數字有效):
  • 附:MySQL group_concat()詳解
  • 總結

前言

總是記不住字符串拼接,每次都要百度去搜索,所以在這里記錄一下,好方便后續的查找,如有錯誤和問題可以提出,謝謝。

字符串拼接分為幾種方式,在這里會一一舉例寫出:

第一種:

mysql自帶語法CONCAT(string1,string2,…),此處是直接把string1和string2等等的字符串拼接起來(無縫拼接哦)

說明:此方法在拼接的時候如果有一個值為NULL,則返回NULL

如:

1.SELECT CONCAT(“name=”,“lich”,NULL) AS test;

2.SELECT CONCAT(“name=”,“lich”) AS test;

第二種:

第二種也是mysql自帶語法CONCAT_WS(separator,string1,string2,…),但是可以多個字符串用指定的字符串進行拼接(帶縫拼接哦)

說明:string1,string2代表的是字符串,而separator代表的是連接其他參數的分隔符,可以是符號,也可以是字符串。如果分隔符為NULL,則結果為NULL。此方法參數可以為NULL。

如:

1.select concat_ws(‘#’,‘name=’,‘lich’,null) AS test;

2.select concat_ws(NULL,‘name=’,‘lich’,null) AS test;

3.select concat_ws(“hello,”,‘name=’,‘lich’,null) AS test;

第三種:

也是mysql的自帶語法GROUP_CONCAT([DISTINCT] 要連接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])

如:

1.SELECT id,GROUP_CONCAT(type) FROM log_sys_interview GROUP BY type ;

2.SELECT id,GROUP_CONCAT(type Separator ‘#’) FROM log_sys_interview GROUP BY type ;

3.SELECT id,GROUP_CONCAT(type ORDER BY type DESC) FROM log_sys_interview GROUP BY ip ;

4.SELECT id,GROUP_CONCAT(DISTINCT type ORDER BY type DESC) FROM log_sys_interview GROUP BY ip ;

第四種(運算,只對數字有效):

這種方式比較簡單

原始的:

SELECT id,type FROM log_sys_interview ;

SELECT id,type+99 FROM log_sys_interview ;

附:MySQL group_concat()詳解

GROUP_CONCAT(xxx):是將分組中括號里對應的字符串進行連接.如果分組中括號里的參數xxx有多行,那么就會將這多行的字符串連接,每個字符串之間會有特定的符號進行分隔。

對應的語法格式

# 將分組中column1這一列對應的多行的值按照column2 升序或者降序進行連接,其中分隔符為seq# 如果用到了DISTINCT,將表示將不重復的column1按照column2升序或者降序連接# 如果沒有指定SEPARATOR的話,也就是說沒有寫,那么就會默認以 ","分隔GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASC\DESC] [SEPARATOR seq]);

[ ORDER BY column2 ASC\DESC] :表示將會根據column2升序或者降序連接.其中column2不一定一定要求是column1,只要保證column2在這個分組中即可.如果沒有寫ORDER BY句段,那么連接是沒有順序的。

[ SEPARATOR seq] : 表示各個column1將會以什么分隔符進行分隔,例如SEPARATOR '’,則表示column1將會以進行分隔。如果沒有指定seq的時候,也即沒有寫SEPARATOR seq這個句段,那么就會默認是以,分隔的。

CONCAT函數中要連接的數據含有NULL,最后返回的是NULL,但是GROUP_CONCAT不會這樣,他會忽略NULL值。

    mysql> SELECT * FROM employee2;      +----+-----------+------+---------+---------+      | id | name      | age  | salary  | dept_id |      +----+-----------+------+---------+---------+      |  3 | 小肖      |   29 | 30000.0 |       1 |      |  4 | 小東      |   30 | 40000.0 |       2 |      |  6 | 小非      |   24 | 23456.0 |       3 |      |  7 | 曉飛      |   30 | 15000.0 |       4 |      |  8 | 小林      |   23 | 24000.0 |    NULL |      | 10 | 小五      |   20 |  4500.0 |    NULL |      | 11 | 張山      |   24 | 40000.0 |       1 |      | 12 | 小肖      |   28 | 35000.0 |       2 |      | 13 | 李四      |   23 | 50000.0 |       1 |      | 17 | 王武      |   24 | 56000.0 |       2 |      | 18 | 豬小屁    |    2 | 56000.0 |       2 |      | 19 | 小玉      |   25 | 58000.0 |       1 |      | 21 | 小張      |   23 | 50000.0 |       1 |      | 22 | 小胡      |   25 | 25000.0 |       2 |      | 96 | 小肖      |   19 | 35000.0 |       1 |      | 97 | 小林      |   20 | 20000.0 |       2 |      +----+-----------+------+---------+---------+      16 rows in set (0.16 sec)            mysql> SELECT  -> dept_id,  -> GROUP_CONCAT(name ORDER BY age DESC SEPARATOR "*") -- 分組中的name中的多行數據將按照age降序進行連接,分隔符為 *   -> FROM employee2  -> GROUP BY dept_id; -- 注意如果這里沒有GROUP BY dept_id,那么就會因為輸出dept_id而發生報錯      +---------+----------------------------------------------------+      | dept_id | GROUP_CONCAT(name ORDER BY age DESC SEPARATOR "*") |      +---------+----------------------------------------------------+      |    NULL | 小林*小五   |      |       1 | 小肖*小玉*張山*小張*李四*小肖  |      |       2 | 小東*小肖*小胡*王武*小林*豬小屁 |      |       3 | 小非|      |       4 | 曉飛|      +---------+----------------------------------------------------+                  mysql> SELECT  -> GROUP_CONCAT(name SEPARATOR "*")   -> FROM employee2; -- 這時候雖然沒有使用GROUP BY,但是可以正常運行,此時是將所有的name連接,連接時為無序,分隔符為*      +-------------------------------------------------------------------------------------------------------+      | GROUP_CONCAT(name SEPARATOR "*")  |       +--------------------------------------------------------------------------------------------------------      | 小肖*小東*小非*曉飛*小林*小五*張山*小肖*李四*王武*豬小屁*小玉*小張*小胡*小肖*小林|       +-------------------------------------------------------------------------------------------------------+      1 row in set (0.00 sec)            mysql> SELECT  -> GROUP_CONCAT(DISTINCT name SEPARATOR "*") -- 將不同的name進行連接  -> FROM employee2;      +-----------------------------------------------------------------------------------------------+      | GROUP_CONCAT(DISTINCT name SEPARATOR "*") |      +-----------------------------------------------------------------------------------------------+      | 小東*小五*小張*小林*小玉*小肖*小胡*小非*張山*曉飛*李四*豬小屁*王武    |      +-----------------------------------------------------------------------------------------------+      1 row in set (0.00 sec)                  mysql> SELECT  -> dept_id,  -> GROUP_CONCAT(name) AS employees  -> FROM employee2  -> GROUP BY dept_id; -- 輸出每個部門的員工,每個員工之間用逗號分隔,因為沒有寫SEPARATOR ,所以就默認以逗號分隔      +---------+----------------------------------------------+      | dept_id | employees    |      +---------+----------------------------------------------+      |    NULL | 小林,小五    |      |       1 | 小肖,張山,李四,小玉,小張,小肖|      |       2 | 小東,小肖,王武,豬小屁,小胡,小林      |      |       3 | 小非 |      |       4 | 曉飛 |      +---------+----------------------------------------------+      5 rows in set (0.00 sec)            mysql> SELECT  -> dept_id,  -> GROUP_CONCAT(DISTINCT name) -- 將不同的name連接,并且用逗號分隔  -> AS employees  -> FROM  employee2  -> GROUP BY dept_id;      +---------+----------------------------------------------+      | dept_id | employees    |      +---------+----------------------------------------------+      |    NULL | 小五,小林    |      |       1 | 小張,小玉,小肖,張山,李四     |      |       2 | 小東,小林,小肖,小胡,豬小屁,王武      |      |       3 | 小非 |      |       4 | 曉飛 |      +---------+----------------------------------------------+      5 rows in set (0.00 sec)

總結

到此這篇關于mysql字符串拼接的4種方式的文章就介紹到這了,更多相關mysql字符串拼接內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MySQL
相關文章:
主站蜘蛛池模板: 航空障碍灯_高中低光强航空障碍灯_民航许可认证航空警示灯厂家-东莞市天翔航天科技有限公司 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 | 有机肥设备生产制造厂家,BB掺混肥搅拌机、复合肥设备生产线,有机肥料全部加工设备多少钱,对辊挤压造粒机,有机肥造粒设备 -- 郑州程翔重工机械有限公司 | 镀锌角钢_槽钢_扁钢_圆钢_方矩管厂家_镀锌花纹板-海邦钢铁(天津)有限公司 | 润东方环保空调,冷风机,厂房车间降温设备-20年深圳环保空调生产厂家 | 「安徽双凯」自动售货机-无人售货机-成人用品-自动饮料食品零食售货机 | 有源电力滤波装置-电力有源滤波器-低压穿排电流互感器|安科瑞 | 2-羟基泽兰内酯-乙酰蒲公英萜醇-甘草查尔酮A-上海纯优生物科技有限公司 | 环压强度试验机-拉链拉力试验机-上海倾技仪器仪表科技有限公司 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | 护栏打桩机-打桩机厂家-恒新重工 | 奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌 | CTAB,表面活性剂1631溴型(十六烷基三甲基溴化铵)-上海升纬化工原料有限公司 | 对夹式止回阀_对夹式蝶形止回阀_对夹式软密封止回阀_超薄型止回阀_不锈钢底阀-温州上炬阀门科技有限公司 | 临朐空调移机_空调维修「空调回收」临朐二手空调 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 进口消泡剂-道康宁消泡剂-陶氏消泡剂-大洋消泡剂 | 河南mpp电力管_mpp电力管生产厂家_mpp电力电缆保护管价格 - 河南晨翀实业 | 魔方网-培训咨询服务平台| 洗地机_全自动洗地机_手推式洗地机【上海滢皓环保】 | 沈阳庭院景观设计_私家花园_别墅庭院设计_阳台楼顶花园设计施工公司-【沈阳现代时园艺景观工程有限公司】 | 成都茶楼装修公司 - 会所设计/KTV装修 - 成都朗煜装饰公司 | 不锈钢监控杆_监控立杆厂家-廊坊耀星光电科技有限公司 | 杭州用友|用友软件|用友财务软件|用友ERP系统--杭州协友软件官网 | 楼承板-钢筋楼承板-闭口楼承板-无锡优贝斯楼承板厂 | 电缆接头-防爆电缆接头-格兰头-金属电缆接头-防爆填料函 | 冷水机-冰水机-冷冻机-冷风机-本森智能装备(深圳)有限公司 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 杭州高温泵_热水泵_高温油泵|昆山奥兰克泵业制造有限公司 | 空气能暖气片,暖气片厂家,山东暖气片,临沂暖气片-临沂永超暖通设备有限公司 | 执业药师报名条件,考试时间,考试真题,报名入口—首页 | 方源木业官网-四川木门-全国木门专业品牌 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 涿州网站建设_网站设计_网站制作_做网站_固安良言多米网络公司 | 名律网-法律问题咨询-找律师-法律知识| 圆盘鞋底注塑机_连帮鞋底成型注塑机-温州天钢机械有限公司 | 切铝机-数控切割机-型材切割机-铝型材切割机-【昆山邓氏精密机械有限公司】 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 耐磨陶瓷,耐磨陶瓷管道_厂家-淄博拓创陶瓷科技 | 12cr1mov无缝钢管切割-15crmog无缝钢管切割-40cr无缝钢管切割-42crmo无缝钢管切割-Q345B无缝钢管切割-45#无缝钢管切割 - 聊城宽达钢管有限公司 | 乐之康护 - 专业护工服务平台,提供医院陪护-居家照护-居家康复 |