函数-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');
相关推荐
JIngJaneIL1 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
微学AI1 小时前
复杂时序场景的突围:金仓数据库是凭借什么超越InfluxDB?
数据库
廋到被风吹走1 小时前
【数据库】【Redis】定位、优势、场景与持久化机制解析
数据库·redis·缓存
有想法的py工程师2 小时前
PostgreSQL + Debezium CDC 踩坑总结
数据库·postgresql
Nandeska3 小时前
2、数据库的索引与底层数据结构
数据结构·数据库
小卒过河01043 小时前
使用apache nifi 从数据库文件表路径拉取远程文件至远程服务器目的地址
运维·服务器·数据库
过期动态3 小时前
JDBC高级篇:优化、封装与事务全流程指南
android·java·开发语言·数据库·python·mysql
Mr.朱鹏3 小时前
SQL深度分页问题案例实战
java·数据库·spring boot·sql·spring·spring cloud·kafka
一位代码3 小时前
mysql | 常见日期函数使用及格式转换方法
数据库·mysql
SelectDB3 小时前
Apache Doris 4.0.2 版本正式发布
数据库·人工智能