欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql字符串拼接的4種方式總結(jié)

 更新時(shí)間:2023年02月15日 10:29:01   作者:奇怪的大象  
MySQL字符串拼接可以使多個(gè)字段的值組成一個(gè)集合,不僅可以拼接字符串與字符串、空格、特殊符號(hào)甚至可以拼接中文文本,下面這篇文章主要給大家介紹了關(guān)于mysql字符串拼接的4種方式,需要的朋友可以參考下

前言

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

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

第一種:

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

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

如:

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

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

第二種:

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

說明:string1,string2代表的是字符串,而separator代表的是連接其他參數(shù)的分隔符,可以是符號(hào),也可以是字符串。如果分隔符為NULL,則結(jié)果為NULL。此方法參數(shù)可以為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 ;

第四種(運(yùn)算,只對(duì)數(shù)字有效):

這種方式比較簡(jiǎn)單

原始的:

SELECT id,type FROM log_sys_interview ;

SELECT id,type+99 FROM log_sys_interview ;

附:MySQL group_concat()詳解

GROUP_CONCAT(xxx):是將分組中括號(hào)里對(duì)應(yīng)的字符串進(jìn)行連接.如果分組中括號(hào)里的參數(shù)xxx有多行,那么就會(huì)將這多行的字符串連接,每個(gè)字符串之間會(huì)有特定的符號(hào)進(jìn)行分隔。

對(duì)應(yīng)的語法格式

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

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

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

CONCAT函數(shù)中要連接的數(shù)據(jù)含有NULL,最后返回的是NULL,但是GROUP_CONCAT不會(huì)這樣,他會(huì)忽略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中的多行數(shù)據(jù)將按照age降序進(jìn)行連接,分隔符為 * 
          -> FROM employee2
          -> GROUP BY dept_id; -- 注意如果這里沒有GROUP BY dept_id,那么就會(huì)因?yàn)檩敵鰀ept_id而發(fā)生報(bào)錯(cuò)
      +---------+----------------------------------------------------+
      | dept_id | GROUP_CONCAT(name ORDER BY age DESC SEPARATOR '*') |
      +---------+----------------------------------------------------+
      |    NULL | 小林*小五                                           |
      |       1 | 小肖*小玉*張山*小張*李四*小肖                          |
      |       2 | 小東*小肖*小胡*王武*小林*豬小屁                         |
      |       3 | 小非                                                |
      |       4 | 曉飛                                                |
      +---------+----------------------------------------------------+
      
      
      mysql> SELECT
          -> GROUP_CONCAT(name SEPARATOR '*') 
          -> FROM employee2; -- 這時(shí)候雖然沒有使用GROUP BY,但是可以正常運(yùn)行,此時(shí)是將所有的name連接,連接時(shí)為無序,分隔符為*
      +-------------------------------------------------------------------------------------------------------+
      | GROUP_CONCAT(name SEPARATOR '*')                                                                      | 
      +--------------------------------------------------------------------------------------------------------
      | 小肖*小東*小非*曉飛*小林*小五*張山*小肖*李四*王武*豬小屁*小玉*小張*小胡*小肖*小林                                | 
      +-------------------------------------------------------------------------------------------------------+
      1 row in set (0.00 sec)
      
      mysql> SELECT
          -> GROUP_CONCAT(DISTINCT name SEPARATOR '*') -- 將不同的name進(jìn)行連接
          -> 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; -- 輸出每個(gè)部門的員工,每個(gè)員工之間用逗號(hào)分隔,因?yàn)闆]有寫SEPARATOR ,所以就默認(rèn)以逗號(hào)分隔
      +---------+----------------------------------------------+
      | dept_id | employees                                    |
      +---------+----------------------------------------------+
      |    NULL | 小林,小五                                    |
      |       1 | 小肖,張山,李四,小玉,小張,小肖                |
      |       2 | 小東,小肖,王武,豬小屁,小胡,小林              |
      |       3 | 小非                                         |
      |       4 | 曉飛                                         |
      +---------+----------------------------------------------+
      5 rows in set (0.00 sec)
      
      mysql> SELECT
          -> dept_id,
          -> GROUP_CONCAT(DISTINCT name) -- 將不同的name連接,并且用逗號(hào)分隔
          -> AS employees
          -> FROM  employee2
          -> GROUP BY dept_id;
      +---------+----------------------------------------------+
      | dept_id | employees                                    |
      +---------+----------------------------------------------+
      |    NULL | 小五,小林                                    |
      |       1 | 小張,小玉,小肖,張山,李四                     |
      |       2 | 小東,小林,小肖,小胡,豬小屁,王武              |
      |       3 | 小非                                         |
      |       4 | 曉飛                                         |
      +---------+----------------------------------------------+
      5 rows in set (0.00 sec)

總結(jié) 

到此這篇關(guān)于mysql字符串拼接的4種方式的文章就介紹到這了,更多相關(guān)mysql字符串拼接內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • InnoDB引擎數(shù)據(jù)庫主從復(fù)制同步新的分享

    InnoDB引擎數(shù)據(jù)庫主從復(fù)制同步新的分享

    近期將公司的MySQL架構(gòu)升級(jí)了,由原先的一主多從換成了DRBD+Heartbeat雙主多從,所以這里也將其心得歸納總結(jié)了一下
    2012-11-11
  • 用mysqldump備份和恢復(fù)指定表的方法

    用mysqldump備份和恢復(fù)指定表的方法

    用mysqldump備份和恢復(fù)指定表的方法...
    2007-07-07
  • 詳解mysql中字符串轉(zhuǎn)為數(shù)字的三種方法

    詳解mysql中字符串轉(zhuǎn)為數(shù)字的三種方法

    這篇文章主要為大家詳細(xì)介紹了mysql中字符串轉(zhuǎn)為數(shù)字的三種常用方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11
  • MySql是否需要commit詳解

    MySql是否需要commit詳解

    在本篇文章里小編給大家分享了關(guān)于MySql是否需要commit的相關(guān)知識(shí)點(diǎn)內(nèi)容,需要的朋友們跟著操作下。
    2019-05-05
  • mysql日志文件General_log和Binlog開啟及詳解

    mysql日志文件General_log和Binlog開啟及詳解

    MySQL中的數(shù)據(jù)變化會(huì)體現(xiàn)在上面日志中,下面這篇文章主要給大家介紹了關(guān)于mysql日志文件General_log和Binlog開啟及詳解的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • MySQL8數(shù)據(jù)庫安裝及SQL語句詳解

    MySQL8數(shù)據(jù)庫安裝及SQL語句詳解

    本文詳細(xì)講解了MySQL8數(shù)據(jù)庫安裝及SQL語句用法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02
  • Windows 8.1下MySQL5.7 忘記root 密碼的解決方法

    Windows 8.1下MySQL5.7 忘記root 密碼的解決方法

    最近學(xué)習(xí)碰到了一件挺令人尷尬的事情,我把MySQL的密碼給忘記了,所以MySQL登錄不進(jìn)去。在網(wǎng)上找的解決方案都不靠譜,下面小編給大家分享Windows 8.1下MySQL5.7 忘記root 密碼的解決方法,需要的朋友一起看看吧
    2017-07-07
  • mysql數(shù)據(jù)庫應(yīng)付大流量網(wǎng)站的的3種架構(gòu)擴(kuò)展方式介紹

    mysql數(shù)據(jù)庫應(yīng)付大流量網(wǎng)站的的3種架構(gòu)擴(kuò)展方式介紹

    這篇文章主要介紹了mysql數(shù)據(jù)庫應(yīng)付大流量網(wǎng)站的的3種架構(gòu)擴(kuò)展方式介紹,它們分別是讀寫分離、垂直分區(qū)、水平分區(qū),本文分別對(duì)它們做了講解,需要的朋友可以參考下
    2014-07-07
  • MySQL如何給表和字段添加注釋

    MySQL如何給表和字段添加注釋

    這篇文章主要介紹了MySQL如何給表和字段添加注釋問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • MySQL select、insert、update批量操作語句代碼實(shí)例

    MySQL select、insert、update批量操作語句代碼實(shí)例

    這篇文章主要介紹了MySQL select、insert、update批量操作語句代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03

最新評(píng)論