函数-1-字符串函数

函数-1-字符串函数

字符串函数

函数

函数是一段可以直接被另一端程序调用的程序或代码

语法

sql 复制代码
SELECT 函数名(参数名)

大家可能会有那么一点点疑惑, 为什么执行函数还需要加上SELECT语句? 总结一下, 因为SELECT语句是MySQL中执行函数并获取结果的标准方式,它能够方便地与其他SQL操作结合,并以简洁的语法完成各种计算和数据处理任务。

字符串函数的使用

MySQL中内置了很多字符串函数, 常用的几个如下:

函数 功能
CONCAT(S1, S2, ..., Sn) 字符串拼接, 将 S1, S2, ..., Sn 拼接成一个字符串
LOWER(str) 将字符串 str 全部转为小写
UPPER(str) 将字符串 str 全部转为大写
LPAD(str, n, pad) 左填充, 用字符串 pad 对 str 的左边进行填充, 达到 n 个字符串长度
RPAD(str, n, pad) 右填充, 用字符串 pad 对 str 的右边进行填充, 达到 n 个字符串长度
TRIM(str) 去掉字符串头部和尾部的空格
SUBSTRING(str, start, len) 返回字符串 str 从 start 位置起的 len 个长度的字符串

字符串函数语法

  1. CONCAT 函数

    sql 复制代码
    SELECT CONCAT(参数)
  2. LOWER 函数

    sql 复制代码
    SELECT LOWER(参数)
  3. UPPER 函数

    sql 复制代码
    SELECT UPPER(参数)
  4. LPAD 函数

    sql 复制代码
    SELECT LPAD(参数)
  5. RPAD 函数

    sql 复制代码
    SELECT RPAD(参数)
  6. TRIM 函数

    sql 复制代码
    SELECT TRIM(参数)

案例演示

  1. 拼接HelloWorld两个字符串

    sql 复制代码
    select concat('Hello', 'World');
  2. Hello, World 字符串所有字母转换成小写字母

    sql 复制代码
    select lower('Hello, World');
  3. Hello, World 字符串所有字母转换成大写字母

    sql 复制代码
    select upper('Hello, World');
  4. 使用 @ 符号对字符串 Hello, World 进行左填充 ,使其总长度达到 20 个字符

    sql 复制代码
    select lpad('Hello, World', 20, '@');
  5. 使用 @ 符号对字符串 Hello, World 进行右填充 ,使其总长度达到 20 个字符

    sql 复制代码
    select rpad('Hello, World', 20, '@');
  6. 去除字符串 Hello, World 首尾的空格

    sql 复制代码
    select trim(' Hello, World ');
  7. 从字符串 Hello, World 中提取子串,得到 llo, Wor

    sql 复制代码
    select substring('Hello, World', 3, 8);

    注意, 此处的起始索引是从1开始算的, 所以需要注意我们切片的时候的起始索引应该是3, 而不是2

实战练习

首先我们需要准备一下数据, 在 test 库的 emp_info 中更新一下数据, 进行如下替换即可

sql 复制代码
INSERT INTO emp_info (id, work_no, name, gender, age, id_card, work_address, entry_time)
VALUES (1, '1', '张伟', '男', 28, '11010519950101234X', '北京市海淀区中关村科技园', '2020-03-15'),
    (2, '2', '李娜', '女', 32, '310115199209076542', '上海市浦东新区张江高科技园区', '2019-07-22'),
    (3, '3', '王超', '男', 25, '440305199801129876', '深圳市南山区高新科技园', '2021-11-05'),
    (4, '4', '赵敏', '女', 29, '510107199412258765', '成都市高新区天府软件园', '2020-09-18'),
    (5, '5', '陈阳', '男', 35, '330106198911034567', '杭州市西湖区云栖小镇', '2018-05-30'),
    (6, '6', '刘婷', '女', 27, '320506199612127890', '苏州市工业园区人工智能产业园', '2022-02-14'),
    (7, '7', '杨帆', '男', 31, '420111199211156789', '武汉市东湖新技术开发区', '2019-10-21'),
    (8, '8', '周雨', '女', 26, '440111199712098765', '广州市天河区智慧城', '2021-08-03'),
    (9, '9', '吴强', '男', 33, '500106198912312345', '重庆市渝北区仙桃数据谷', '2017-04-12'),
    (10, '10', '郑琳', '女', 30, '610113199310214567', '西安市高新区软件新城', '2020-01-25');
  1. 由于业务需求变更, 企业员工的工号, 统一为 5 位数, 目前不足 5 位数的全部在前面补 0, 例如: 1 号员工的公号应该为 00001

    这题其实不是很复杂, 但咱可以稍微搞复杂一些, 顺便回顾一下之前的知识点

    首先查看一下建表语句, 获取一下各字段信息

    sql 复制代码
    desc emp_info;

    查看到表结构, 我们需要统一的企业员工的工号字段为 work_no, 类型为 varchar(10)

    再查看一下表内容

    sql 复制代码
    select *
    from emp_info;

    这里其实可以发现, work_no 字段都不足 5 位数, 但是字段类型却为 varchar(10), 所以我们可以尝试修改以下表的结构, 将其统一为 char(5), 当然只作练习使用, 不适用于生产环境, 生产环境还是得因地制宜, 按照企业的意思进行管理, 这里只做学习!!!

    修改 work_no 字段类型为 char(5)

    sql 复制代码
    alter table emp_info
        modify work_no char(5);

    再次查看表结构以确认修改结果

    使用左补全, 补全员工工号字段, 并且更新到表中, 这里其实大家就能明白, 使用函数不一定要带有 SELECT

    sql 复制代码
    update emp_info
    set work_no=lpad(emp_info.work_no, 5, '0');
相关推荐
float_六七37 分钟前
SQL六大核心类别全解析
数据库·sql·oracle
Code季风2 小时前
将 gRPC 服务注册到 Consul:从配置到服务发现的完整实践(上)
数据库·微服务·go·json·服务发现·consul
Boilermaker19922 小时前
【Java EE】SpringIoC
前端·数据库·spring
霸王龙的小胳膊3 小时前
泛微虚拟视图-数据虚拟化集成
数据库
灵犀学长3 小时前
解锁Spring Boot多项目共享Redis:优雅Key命名结构指南
数据库·redis
轩情吖3 小时前
Qt的信号与槽(二)
数据库·c++·qt·信号·connect·信号槽·
ZeroNews内网穿透3 小时前
服装零售企业跨区域运营难题破解方案
java·大数据·运维·服务器·数据库·tcp/ip·零售
可观测性用观测云3 小时前
达梦数据库监控观测最佳实践
数据库
时序数据说3 小时前
IoTDB:专为物联网场景设计的高性能时序数据库
大数据·数据库·物联网·开源·时序数据库·iotdb
码农小站5 小时前
ClickHouse 时间范围查询:精准筛选「本月数据」
数据库