mysql的concat函數_MySQL中concat函數(連接字符串)

MySQL中concat函數

使用方法:

CONCAT(str1,str2,…)

返回結果為連接參數產生的字符串。如有任何一個參數為NULL?,則返回值為?NULL。

注意:

如果所有參數均為非二進制字符串,則結果為非二進制字符串。

如果自變量中含有任一二進制字符串,則結果為一個二進制字符串。

一個數字參數被轉化為與之相等的二進制字符串格式;若要避免這種情況,可使用顯式類型?cast,?例如:

SELECT?CONCAT(CAST(int_col?AS?CHAR),?char_col)

MySQL的concat函數可以連接一個或者多個字符串,如

mysql>?select?concat('10');

+--------------+

|?concat('10')?|

+--------------+

|?10???|

+--------------+

1?row?in?set?(0.00?sec)

mysql>?select?concat('11','22','33');

+------------------------+

|?concat('11','22','33')?|

+------------------------+

|?112233?|

+------------------------+

1?row?in?set?(0.00?sec)

MySQL的concat函數在連接字符串的時候,只要其中一個是NULL,那么將返回NULL

mysql>?select?concat('11','22',null);

+------------------------+

|?concat('11','22',null)?|

+------------------------+

|?NULL???|

+------------------------+

1?row?in?set?(0.00?sec)

MySQL中concat_ws函數使用方法:

CONCAT_WS(separator,str1,str2,...)

CONCAT_WS()?代表?CONCAT?With?Separator?,是CONCAT()的特殊形式。第一個參數是其它參數的分隔符。分隔符的位置放在要連接的兩個字符串之間。分隔符可以是一個字符串,也可以是其它參數。

注意:

如果分隔符為?NULL,則結果為?NULL。函數會忽略任何分隔符參數后的?NULL?值。

如連接后以逗號分隔

mysql>?select?concat_ws(',','11','22','33');

+-------------------------------+

|?concat_ws(',','11','22','33')?|

+-------------------------------+

|?11,22,33?|

+-------------------------------+

1?row?in?set?(0.00?sec)

和MySQL中concat函數不同的是,?concat_ws函數在執行的時候,不會因為NULL值而返回NULL

mysql>?select?concat_ws(',','11','22',NULL);

+-------------------------------+

|?concat_ws(',','11','22',NULL)?|

+-------------------------------+

|?11,22?|

+-------------------------------+

1?row?in?set?(0.00?sec)

MySQL中group_concat函數

完整的語法如下:

group_concat([DISTINCT]?要連接的字段?[Order?BY?ASC/DESC?排序字段]?[Separator?'分隔符'])

基本查詢

mysql>?select?*?from?aa;

+------+------+

|?id|?name?|

+------+------+

|1?|?10|

|1?|?20|

|1?|?20|

|2?|?20|

|3?|?200???|

|3?|?500???|

+------+------+

6?rows?in?set?(0.00?sec)

以id分組,把name字段的值打印在一行,逗號分隔(默認)

mysql>?select?id,group_concat(name)?from?aa?group?by?id;

+------+--------------------+

|?id|?group_concat(name)?|

+------+--------------------+

|1?|?10,20,20|

|2?|?20?|

|3?|?200,500|

+------+--------------------+

3?rows?in?set?(0.00?sec)

以id分組,把name字段的值打印在一行,分號分隔

mysql>?select?id,group_concat(name?separator?';')?from?aa?group?by?id;

+------+----------------------------------+

|?id|?group_concat(name?separator?';')?|

+------+----------------------------------+

|1?|?10;20;20?|

|2?|?20|

|3?|?200;500???|

+------+----------------------------------+

3?rows?in?set?(0.00?sec)

以id分組,把去冗余的name字段的值打印在一行,

逗號分隔

mysql>?select?id,group_concat(distinct?name)?from?aa?group?by?id;

+------+-----------------------------+

|?id|?group_concat(distinct?name)?|

+------+-----------------------------+

|1?|?10,20|

|2?|?20???|

|3?|?200,500?|

+------+-----------------------------+

3?rows?in?set?(0.00?sec)

以id分組,把name字段的值打印在一行,逗號分隔,以name排倒序

mysql>?select?id,group_concat(name?order?by?name?desc)?from?aa?group?by?id;

+------+---------------------------------------+

|?id|?group_concat(name?order?by?name?desc)?|

+------+---------------------------------------+

|1?|?20,20,10???|

|2?|?20|

|3?|?500,200|

+------+---------------------------------------+

3?rows?in?set?(0.00?sec)

repeat()函數

用來復制字符串,如下'ab'表示要復制的字符串,2表示復制的份數

mysql>?select?repeat('ab',2);

+----------------+

|?repeat('ab',2)?|

+----------------+

|?abab???????????|

+----------------+

1?row?in?set?(0.00?sec)

又如

mysql>?select?repeat('a',2);

+---------------+

|?repeat('a',2)?|

+---------------+

|?aa????????????|

+---------------+

1?row?in?set?(0.00?sec)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/277582.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/277582.shtml
英文地址,請注明出處:http://en.pswp.cn/news/277582.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

利用airTest的圖像實別技術測試Web應用

airTest的第三方類庫中有圖像實別功能,根據官網的介紹,這個功能是能夠在Windows上用來定位元素,進行操作的。嘗試過以下腳本,發現真的可以。 from selenium.webdriver.chrome.options import Options from selenium import webdri…

MySQL主從復制故障解決

叢庫復制停止,進叢庫查看,報錯1007,數據庫已存在,不能創建數據庫 mysql> show slave status\G; Slave_IO_Running: Yes Slave_SQL_Running: No Last_Errno: 1007 Last_Error: Error Cant create database test; database exis…

Unraveling the JPEG file

(文章還剩實踐部分沒寫,答辯過后補上...) JPEG文件在當下數字化生活中是無處不在的,但是在熟悉的JPEG面紗背后,隱藏著一些算法,它們去除了人類眼中無法察覺到的細節。這產生了最高的視覺質量與最小的文件大小。讓我們來看看這一算…

mysql interval 3 day_Mysql之INTERVAL與DATE_SUB與EXTRACT函數的使用

1. INTERVALINTERVAL代表的是時間間隔MySQL中的時間間隔類型有如下幾種:1.1 利用INTERVAL做時間的加減法示例:加法:SQL>SELECT DATE 2018-11-01 INTERVAL 10 11 DAY_HOUR;結果:2018-11-11 11:00:00減法:SQL> select date 2018-11-11 11:00:00 -INT…

(二十四)面向對象

class Car {int num;String name;String color;public static void run() {System.out.println("行駛中");} } //再類中定義的變量:成員變量 //在類中定義的函數:成員函數 class Demo1 {public static void main(String[] args) {//創建一個ca…

mysql 三主_MySQL主主復制3

一、創建并授權用戶在每一臺(主)服務器上創建一個用戶,并為之授權,使它們可以互相訪問彼此的數據庫在Server-1上:創建一個充許Server-2來訪問的用戶server2,密碼為:server2mysql> GRANT REPLICATION SLAVE ON *.*> TO ‘ser…

0727日志

為什么80%的碼農都做不了架構師?>>> c端線上地址 http://x.diandanme.com/fe/?d183#/ 什么時候來需求,我做好準備了嗎? eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC94LmRpYW5kYW5tZS5jb21cL2FwaVwvd2VjaGF0XC…

Python基礎學習總結__Day3

一、集合 1.特性:無序且天生去重,格式為{} 2.作用: (1)去重 (2)關系測試 3.可調用函數(常見對列表操作) (1)取…

day8網絡編程,面向對象1

一.只是回顧 1.導入模塊的順序,首先從當前目錄下找,再從環境變量里面找,使用"sys.path.insert(0,需要導入的環境變量)"加入需要導入文件的環境變量; 2.如果不同項目中有相同的文件,需要導入文件,需要將非當前項目中右鍵添加的環境變量取消,將當前的環境變量添加上去;…

mysql練手數據_MySQL新手練習

操作插入數據 的語法 :INSERT INTO 表名稱 VALUES(值1,值2,......);修改數據 的語法:UPDATE 表名稱 SET 字段名1 值1, 字段名2值2,...... 【WHERE 條件】;刪除數據 的語法:delete from 表名 【[where 條件】;delete 表1&#xff…

spring security config

spring secuirty 相關的配置解析 permitAll()與web.ignoring() ingore是完全繞過了spring security的所有filter,相當于不走spring securitypermitall沒有繞過spring security,其中包含了登錄的以及匿名的。轉載于:https://www.cnblogs.com/MND1024/p/10…

TSPITR方式數據庫找回誤操作丟失的數據

一、TSPITR介紹 TSPITR全稱是Tablespace Point In Time Recover(表空間基于時間點的不完全恢復)。原理是通過輔助實例基于時間還原出誤操作前的數據通過DataPump將數據導入到目標數據庫。TSPITR的最大好處是不需要生產庫停機。 二、適用場景 表空間時點恢…

烏班圖系統的MySQL_烏班圖系統mysql主從備份

一.準備系統:ubuntu 14.04.2 LTSMysql: server version 5.5.43兩臺主機可以互相通信:192.168.1.11 master192.168.1.12 slave二.步驟Master部分:1.創建備份帳號:slave密碼:slaveGrant repl…

mysql table alter_MySQL-ALTER TABLE命令學習[20180503]

學習ALTER TABLE刪除、添加和修改字段和類型CREATE TABLE alter_tab01(id int,col01 char(20))enginInnoDB default charsetutf8;刪除字段ALTER TABLE DROP ;mysql> alter table alter_tab01 dropcol01;Query OK, 0 rows affected (0.01sec)Records: 0 Duplicates: 0 Warnin…

時間戳轉換

13 位時間戳轉換 1 通過java,如下: public static String timeStamp2Date(String time) {Long timeLong Long.parseLong(time);SimpleDateFormat sdf new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//要轉換的時間格式Date date;try {date …

React.Component(V16.8.6)

組件的生命周期 掛載 當組件實例被創建并插入 DOM 中時,其生命周期調用順序如下: constructor()static getDerivedStateFromProps()render()componentDidMount()componentWillMount() 之后將廢棄 更新 當組件的 props 或 state 發生變化時會觸發更新。組…

mysql date類型加一個月jdbc_JDBC操作數據庫Date類型數據

JDBC操作數據庫Date類型數據由于java原生的工具類java.util提供的Date對象與JDBC提供的Date對象并不相同分別是java.util.Date和java.sql.Datejava.sql.Date是java.util.Date的子類所以在進行增刪改查部分操作中,不能直接將原生工具類的Date對象直接運用到JDBC中可以…

使用深度學習TensorFlow框架進行圖片識別

Apsara Clouder大數據專項技能認證:使用深度學習TensorFlow框架進行圖片識別本認證系統的介紹了深度學習的一些基礎知識,以及Tensorflow的工作原理。通過阿里云機器學習PAI基于經典的CIFAR-10數據集實現圖片識別。學員可以通過本實驗,對深度學…

刪除開發分支 新建另一個開發分支

//查看狀態 git status //查看分支 會有一個分支git branch -d wlh-dev git branch //刪除wlh-dev 分支 git branch -d wlh-dev //再次查看分支 git branch //拉代碼 git pull //查看狀態 git status //新分支創建的同時切換分支 git checkout -b wlh-dev1222 //…

ES語法及-IK分詞器

{"query": {"query_string": {"default_field": "title",//全文搜索"query": "器大"}} } "id":1, "title":"Elasticsearch是一個基于Lucene的搜索服務器", "content":&q…