函数-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');
相关推荐
大佐不会说日语~2 小时前
Redis高频问题全解析
java·数据库·redis
IT北辰2 小时前
用Python+MySQL实战解锁企业财务数据分析
python·mysql·数据分析
会飞的灰大狼2 小时前
初识数据库
数据库
旋风菠萝4 小时前
JVM易混淆名称
java·jvm·数据库·spring boot·redis·面试
AWS官方合作商5 小时前
Amazon RDS for MySQL成本优化:RDS缓存降本实战
数据库·mysql·aws
77qqqiqi5 小时前
解决Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are required报错问题
java·数据库·微服务·mybatis·mybatisplus
眺望电子-ARM嵌入式6 小时前
技术笔记 | Ubuntu 系统 OTA 升级全流程详解
数据库·postgresql·php
程序猿小D7 小时前
Java项目:基于SSM框架实现的校园活动资讯网管理系统【ssm+B/S架构+源码+数据库+毕业论文+远程部署】
java·数据库·mysql·spring·毕业设计·ssm框架·校园活动
数据要素X7 小时前
【数据架构08】数字化转型架构篇
大数据·数据库·数据仓库·架构·数据库架构
百川7 小时前
sqli-labs靶场Less24
sql·web安全