MySQL内置函数表

2018/07 作者:ihunter 0 0

ASCII(str) 

 返回字符串str的第一个字符的ASCII值(str是空串时返回0) 

ORD(str) 

 如果字符串str句首是单字节返回与ASCII()函数返回的相同值。 

 如果是一个多字节字符,以格式返回((first byte ASCII code)*256+(second byte ASCII code))[*256+third byte ASCII code...] 

mysql> select ORD('2'); 

  -> 50 

CONV(N,from_base,to_base) 

 对数字N进制转换,并转换为字串返回(任何参数为NULL时返回NULL,进制范围为2-36进制,当to_base是负数时N作为有符号数否则作无符号数,CONV以64位点精度工作) 

mysql> select CONV("a",16,2); 

  -> '1010' 

mysql> select CONV("6E",18,8); 

  -> '172' 

mysql> select CONV(-17,10,-18); 

  -> '-H' 

mysql> select CONV(10+"10"+'10'+0xa,10,10); 

  -> '40' 

BIN(N) 

 把N转为二进制值并以字串返回(N是BIGINT数字,等价于CONV(N,10,2)) 

mysql> select BIN(12); 

  -> '1100' 

OCT(N) 

 把N转为八进制值并以字串返回(N是BIGINT数字,等价于CONV(N,10,8)) 

mysql> select OCT(12); 

  -> '14' 

HEX(N) 

 把N转为十六进制并以字串返回(N是BIGINT数字,等价于CONV(N,10,16)) 

mysql> select HEX(255); 

  -> 'FF' 

CHAR(N,...) 

 返回由参数N,...对应的ASCII代码字符组成的一个字串(参数是N,...是数字序列,NULL值被跳过) 

mysql> select CHAR(77,121,83,81,'76'); 

  -> 'MySQL' 

mysql> select CHAR(77,77.3,'77.3'); 

  -> 'MMM' 

CONCAT(str1,str2,...) 

 把参数连成一个长字符串并返回(任何参数是NULL时返回NULL) 

mysql> select CONCAT('My', 'S', 'QL'); 

  -> 'MySQL' 

mysql> select CONCAT('My', NULL, 'QL'); 

  -> NULL 

mysql> select CONCAT(14.3); 

  -> '14.3' 

LENGTH(str) 

OCTET_LENGTH(str) 

CHAR_LENGTH(str) 

CHARACTER_LENGTH(str) 

 返回字符串str的长度(对于多字节字符CHAR_LENGTH仅计算一次) 

mysql> select LENGTH('text'); 

  -> 4 

mysql> select OCTET_LENGTH('text'); 

  -> 4 

LOCATE(substr,str) 

POSITION(substr IN str) 

 返回字符串substr在字符串str第一次出现的位置(str不包含substr时返回0) 

mysql> select LOCATE('bar', 'foobarbar'); 

  -> 4 

mysql> select LOCATE('xbar', 'foobar'); 

  -> 0 

LOCATE(substr,str,pos) 

 返回字符串substr在字符串str的第pos个位置起第一次出现的位置(str不包含substr时返回0) 

mysql> select LOCATE('bar', 'foobarbar',5); 

  -> 7 

INSTR(str,substr) 

 返回字符串substr在字符串str第一次出现的位置(str不包含substr时返回0) 

mysql> select INSTR('foobarbar', 'bar'); 

  -> 4 

mysql> select INSTR('xbar', 'foobar'); 

  -> 0 

LPAD(str,len,padstr) 

 用字符串padstr填补str左端直到字串长度为len并返回 

mysql> select LPAD('hi',4,'??'); 

  -> '??hi' 

RPAD(str,len,padstr) 

 用字符串padstr填补str右端直到字串长度为len并返回 

mysql> select RPAD('hi',5,'?'); 

  -> 'hi???' 

LEFT(str,len) 

 返回字符串str的左端len个字符 

mysql> select LEFT('foobarbar', 5); 

  -> 'fooba' 

RIGHT(str,len) 

 返回字符串str的右端len个字符 

mysql> select RIGHT('foobarbar', 4); 

  -> 'rbar' 

SUBSTRING(str,pos,len) 

SUBSTRING(str FROM pos FOR len) 

MID(str,pos,len) 

 返回字符串str的位置pos起len个字符(使用FROM的丑陋语法是ANSI SQL92标准) 

mysql> select SUBSTRING('Quadratically',5,6); 

  -> 'ratica' 

SUBSTRING(str,pos) 

SUBSTRING(str FROM pos) 

 返回字符串str的位置pos起的一个子串 

mysql> select SUBSTRING('Quadratically',5); 

  -> 'ratically' 

mysql> select SUBSTRING('foobarbar' FROM 4); 

  -> 'barbar' 

SUBSTRING_INDEX(str,delim,count) 

 返回从字符串str的第count个出现的分隔符delim之后的子串(count为正数时返回左端,否则返回右端子串) 

mysql> select SUBSTRING_INDEX('www.mysql.com', '.', 2); 

  -> 'www.mysql' 

mysql> select SUBSTRING_INDEX('www.mysql.com', '.', -2); 

  -> 'mysql.com' 

LTRIM(str)

赞(2) 更多分享

上篇: MySQL常用命令
下篇: 在CentOS7中利用yum命令安装mysql