zoukankan      html  css  js  c++  java
  • mysql查询语句常用字段操作函数

    一、concat()函数

    1、功能:将多个字符串连接成一个字符串。

    2、语法:concat(str1, str2,...)

    返回结果为连接参数产生的字符串,如果有任何一个参数为null,则返回值为null。

    3、举例:

    例1:select concat (id, name, score) as info from tt2;

    同时该函数可以实现某个字段加前缀后缀:

    添加前缀
    UPDATE `table` SET field_name = concat("前缀", field_name);
    添加后缀
    UPDATE `table` SET field_name = concat(field_name, "后缀");


    二、concat_ws()函数

    1、功能:和concat()一样,将多个字符串连接成一个字符串,但是可以一次性指定分隔符~(concat_ws就是concat with separator)

    2、语法:concat_ws(separator, str1, str2, ...)

    说明:第一个参数指定分隔符。需要注意的是分隔符不能为null,如果为null,则返回结果为null。

    3、举例:

    例3:我们使用concat_ws()将 分隔符指定为逗号,达到与例2相同的效果:

    select concat (',' , id, name, score) as info from tt2;

    三、group_concat()函数

    前言:在有group by的查询语句中,select指定的字段要么就包含在group by语句的后面,作为分组的依据,要么就包含在聚合函数中。
    1、功能:将group by产生的同一个分组中的值连接起来,返回一个字符串结果。

    2、语法:group_concat( [distinct] 要连接的字段 [order by 排序字段 asc/desc ] [separator '分隔符'] ) 

    说明:通过使用distinct可以排除重复值;如果希望对结果中的值进行排序,可以使用order by子句;separator是一个字符串值,缺省为一个逗号。

    3、举例:

    语句 SELECT locus,GROUP_CONCAT(id) FROM info WHERE locus IN('AB086827','AF040764') GROUP BY locus; 的返回结果为

    | locus         | GROUP_CONCAT(id) |
    | AB086827 | 1,2                               |
    | AF040764 | 23,24                           |

    四、字符串截取函数

    1、从左开始截取字符串 
    left(str, length) 
    说明:left(被截取字段,截取长度) 
    例:select left(content,200) as abstract from my_content_t 

    2、从右开始截取字符串 
    right(str, length) 
    说明:right(被截取字段,截取长度) 
    例:select right(content,200) as abstract from my_content_t 

    3、截取字符串 
    substring(str, pos) 
    substring(str, pos, length) 
    说明:substring(被截取字段,从第几位开始截取) 
    substring(被截取字段,从第几位开始截取,截取长度) 如果截取长度为0则表示截取到最后一位
    例:select substring(content,5) as abstract from my_content_t 
    select substring(content,5,200) as abstract from my_content_t 
    (注:如果位数是负数 如-5 则是从后倒数位数,到字符串结束或截取的长度) 

    4、按关键字截取字符串 
    substring_index(str,delim,count) 
    说明:substring_index(被截取字段,关键字,关键字出现的次数) 
    例:select substring_index("blog.jb51.net",".",2) as abstract from my_content_t 
    结果:blog.jb51 
    (注:如果关键字出现的次数是负数 如-2 则是从后倒数,到字符串结束)

    五、批量替换  REPLACE

    UPDATE `table` SET field_name = REPLACE(field_name, "before_replace", "after_replace");

    用该函数可以实现批量替换某个字段里面的某一部分内容

  • 相关阅读:
    C#操作注册表
    redis在Windows下以后台服务一键搭建哨兵(主从复制)模式(多机)
    redis在Windows下以后台服务一键搭建哨兵(主从复制)模式(单机)
    redis在Windows下以后台服务一键搭建集群(多机器)
    redis在Windows下以后台服务一键搭建集群(单机--伪集群)
    Redis集群维护、运营的相关命令与工具介绍
    Protocol Buffer学习教程之类库应用(四)
    ArcGIS镶嵌数据集的应用-栅格显示范围控制
    QGIS加载与编辑视图图层
    ArcGIS属性域Domain探索
  • 原文地址:https://www.cnblogs.com/myIvan/p/9333416.html
Copyright © 2011-2022 走看看