MySQL--》如何在SQL中巧妙运用函数与约束,优化数据处理与验证?

目录

函数使用

字符串函数

数值函数

日期函数

流程函数

约束

外键约束

约束规则


函数使用

函数是指一段可以直接被另一段程序调用的程序或代码,在mysql当中有许多常见的内置函数,接下来开始对这些内置函数及其作用进行简单的讲解和使用:

字符串函数

mysql中内置了很多的字符串函数,常见的有如下几个:

函数

功能

concat(s1,s2,s3…)

字符串拼接,将s1,s2,s3…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个长度的字符串

接下来对上面的这些字符串函数一一进行一个演示,具体如下所示:

需求案例: 由于业务需求变更,企业员工的工号统一为5位数,目前不足5位数的全部在前面补0,比如1号员工的工号应该为00001,以下面这张员工表为例进行补0:

根据上面这张表想想我们该如何给工号前面补0呢?这里我们用到update函数,直接执行如下命令

update emp set workno = lpad(workno, 5, '0');

数值函数

mysql中内置了很多的数值函数,常见的有如下几个:

函数

功能

ceil(x)

向上取整

floor(x)

向下取整

mod(x,y)

返回x/y的模

rand()

返回0~1内的随机数

round(x,y)

求参数x的四舍五入的值,保留y位小数

接下来对上面的这些字符串函数一一进行一个演示,具体如下所示:

需求案例:通过数据库的函数,生成一个六位数的随机验证码,这个时候应该第一时间想到数值函数当中的生成随机数,但是其生成的是小数,如何操作呢?请往下看:

这里我们就借助数值函数的随机数,四舍五入以及左填充的方式实现,语句如下:

-- 生成六位随机数,包含小数
select rand()*1000000;
-- 生成六位随机数, 进行四舍五入保留0位小数
select round(rand()*1000000, 0);
 -- 生成六位随机数,可以出现小于6位的情况,如0.0012312,不足6位前面补0
select lpad(round(rand()*1000000, 0), 6, '0');

日期函数

mysql中内置了很多的日期函数,常见的有如下几个:

函数

功能

curdate()

返回当前日期

curtime()

返回当前时间

now()

返回当前日期和时间

year(date)

获取指定date的年份

month(date)

获取指定date的月份

day(date)

获取指定date的日期

date_add(date, interval, expr type)

返回应该日期/时间加上一个时间间隔expr后的时间值

datediff(date1, date2)

返回起始时间date1和结束时间date2之间的天数

接下来对上面的这些日期函数一一进行一个演示,具体如下所示:

需求案例:查询所有员工的入职天数并根据入职天数倒序排序,这里我们使用如下这张表进行演示讲解:

想想应该怎么做呢?这里直接获取表中所有的员工姓名,其入职天数等于当前时间和入职时间的间隔,然后再以这个间隔进行降序排序即可,语句如下:

select name, datediff(curdate(), entrydate) as 'entryDays' from emp order by entryDays desc;

流程函数

流程函数也是很常用的一类函数,可以在sql语句中实现条件筛选从而提高语句的效率,常见语句如下:

函数

功能

if(value, t, f)

如果value为true,则返回t,否则返回f

ifnull(value1, value2)

如果value1不为空,则返回value1,否则返回value2

case when [val1] then [res1]…else [default] end

如果val1为true,则返回res1,…,否则返回default默认值

case [expr] when [val1] then [res1]…else [default] end

如果expr值为val1则返回res1,…否则返回default默认值

接下来对上面的这些流程函数一一进行一个演示,首先这里先演示一下if语句,具体如下所示:

接下来我们要实现对员工表当中的工作地址进行筛选,如果工作地址是北京/上海等地返回一线城市,否则返回二线城市,具体如下所示:

需求案例:根据一张学生表的语数外成绩,分别设置优秀、及格、不及格三种情况,如下:

我们先创建一张学生表,想想如何创建表并赋值数据呢?直接看如下语句:

create table students (
    id int comment '学号',
    name varchar(20) comment '姓名',
    chinese int comment '语文成绩',
    math int comment '数学成绩',
    english int comment '英语成绩'
) comment '学生表';
insert into students values (1, '张三', 80, 90, 75), (2, '李四', 15, 80, 90), (3, '王五', 70, 65, 40);

接下来我们开始对这张学生表的成绩进行分类,大于85优秀、大于60及格、小于60不及格:

约束

约束是作用于表中字段上的规则,用于限制存储在表中的数据的,是为了保证数据库中数据的正确、有效性和完整性,对于约束的分类主要分为以下几种:

约束

描述

关键字

非空约束

限制字段的数据不能为null

not null

唯一约束

保证字段的所有数据唯一、不重复

unique

主键约束

主键是一行数据的唯一标识,要求非空且唯一

primary key

默认约束

保存数据如果未指定该字段的值则采用默认值

default

检查约束(8.0.16版本之后)

保证字段值满足某一条件

check

外键约束

用来让两张表之间的数据建立连接,保证数据的一致性和完整性

forelgn key

如下我们可以根据下面这张表的需求完成表的结构创建:

这里我们直接执行如下命令并往表中插入一些数据:

-- 创建表
create table user (
    id int primary key auto_increment comment '主键',
    name varchar(10) not null unique comment '姓名',
    age int check ( age > 0 && age < 120 ) comment '年龄',
    status char(1) default '1' comment '状态',
    gender char(1) comment '性别'
) comment '用户表';
-- 插入数据
insert into user (name, age, status, gender) values ('张三', 20, '1', '男'), ('李四', 30, '1', '女' );
insert into user (name, age, status, gender) values ('王五', 40, '2', '男');

如下生成的表中自动生成主键并递增,大家可以尝试输入错误的年龄,重复的姓名试一试,数据库都是创建数据失败的:

当然我们也可以借助图形化工具datagrip,直接新建表格然后设置约束,如下所示:

外键约束

外键是用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性,如下可以通过员工表的dept_id字段与部门表建立连接:

在主外键关系当中我们把部门表称为父表(外键所关联的表称为父表),员工表称为子表(具有外键的表称为子表),当然有时候我们也可以将其称为主表和从表,目前下面这两张表在数据库层面并未建立外键关联,所以是无法保证数据的一致性和完整性的:

添加外键:为了让两张表之间产生关联,这里我们就需要借助外键约束,添加外键的方式进行,语法如下:

create table 表名 (
    字段名 字段类型
    ...
    constraint 外键名称 foreign key 外键字段名 references 主表(主表列名)
);
alter table 表名 add constraint 外键名称 foreign key 外键字段名 references 主表(主表列名);

接下来我们先创建一下员工表和部门表这两张表出来,语句如下:

-- 准备数据
create table dept(
    id int auto_increment primary key comment 'ID',
    name varchar(50) not null comment '部门名称'
)comment '部门表';
insert into dept(id, name) values (1, '研发部'), (2, '市场部'), (3, '财务部'), (4, '人事部'), (5, '行政部');

create table emploee(
    id int auto_increment primary key comment 'ID',
    name varchar(50) not null comment '姓名',
    age int comment '年龄',
    job varchar(20) comment '职位',
    salary int comment '薪资',
    entrydate date comment '入职时间',
    manager_id int comment '直属上级ID',
    dept_id int comment '部门ID'
)comment '员工表';
insert into emploee(id, name, age, job, salary, entrydate, manager_id, dept_id) values
    (1, '张三', 20, '经理', 5000, '2019-03-04', null, 1),(2, '李四', 30, '主管', 3500, '2019-04-07', 1, 1),
    (3, '王五', 40, '主管', 3500, '2019-06-07', 1, 2), (4, '赵六', 35, '主管', 3000, '2019-08-07', 1, 3),
    (5, '钱七', 28, '主管', 3000, '2019-07-07', 1, 4), (6, '孙八', 25, '主管', 3000, '2019-06-07', 1, 4)

两张表创建完成之后,我们直接执行下面这条语句,给员工表添加外键约束,关联主表的id:

-- 添加外键
alter table emploee add constraint fk_emploee_dept foreign key (dept_id) references dept(id);

执行完成之后可以看到下图dept_id这个字段出现了蓝色的小钥匙,蓝色代表外键,而黄色的小钥匙代表的是主键:

ok,然后我们可以在datagrip中删除一下部门表中的数据,可以看到数据是不能被删除的,因为部门表是关联着员工表的数据的,是不能被删除的,这里保证了数据的一致性和完整性:

删除外键:如果真的想删除外键关联的主表数据,这里我们可以将外键删除掉,这里两张没有外键约束的表就可以任意进行删除了,执行如下语句删除外键即可:

alter table 表名 drop foreign key 外键名称;

这里我们直接执行如下语句删除刚刚我们创建的外键,可以看到我们可以删除主表数据了:

-- 删除外键
alter table emploee drop foreign key fk_emploee_dept;

约束规则

其实外键更新和删除的时候都遵循以下表格中的规则,如下所示:

行为

说明

no action

当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,

如果有则不允许删除/更新。(与RESTRICT一致)

restrict

当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,

如果有则不允许删除/更新。(与NOACTION一致)

cascade

当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,

如果有则也删除/更新外键在子表中的记录。

set null

当在父表中删除对应记录时,首先检查该记录是否有对应外键,

如果有则设置子表中该外键值为nul(这就要求该外键允许取null).

set default

父表有变更时,子表将外键列设置成一个默认的值(Innodb不支持)

这里我们可以在创建外键的时候,可以设置on update在更新时如何操作,on delete在删除时如何操作,添加这样的规则可以更加方便的处理外键的联系,举例语句如下:

alter table 表名 add constraint 外键名称 foreign key 外键字段 references 主表名(主表字段名) on update cascade on delete cascade;

这里我们做一个演示,添加外键的时候设置删除和更新的规则是cascade,也就是删除和更新主表 的时候,子表也会跟着发送变化,如下所示:

当然如果我们设置更新和删除的时候,规则设置set null,效果也是如下所示:

当然这里我们也可以借助图形化工具直接给表设置外键的规则,很方便:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/947428.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

OpenLinkSaas使用手册-待办事项和通知中心

在OpenLinkSaas工作台上&#xff0c;你可以查看待办事项和未读通知。 待办事项 目前待办事项支持: 个人待办项目待办:在项目中指派给你的任务/缺陷Git待办:在Git仓库中指标给你的Issue,目前只有在AtomGit和Gitee账号登录时才支持。 通知中心 通知中心支持Git通知和邮件通知两种…

【Unity】 HTFramework框架(五十八)【进阶篇】资源及代码热更新实战演示(Deployment + HybridCLR)

更新日期&#xff1a;2025年1月2日。 Github源码&#xff1a;[点我获取源码] 索引 资源及代码热更新实战演示运行演示Demo1.克隆项目工程2.更新子模块3.打开项目4.打开入口场景5.设置远端资源服务器地址6.导入HybridCLR7.初始化HybridCLR8.发布项目9.部署资源版本10.运行Exe11.…

路由基本配置实验

路由器用于实现不同类型网络之间的互联。 路由器转发ip分组的基础是路由表。 路由表中的路由项分为直连路由项、静态路由项和动态路由项。 通过配置路由器接口的ip地址和子网掩码自动生成直连路由项。 通过手工配置创建静态路由项。 热备份路由器协议允许将由多个路由器组…

CTFshow—远程命令执行

29-35 Web29 代码利用正则匹配过滤了flag&#xff0c;后面加了/i所以不区分大小写。 可以利用通配符绕过 匹配任何字符串&#xff0f;文本&#xff0c;包括空字符串&#xff1b;*代表任意字符&#xff08;0个或多个&#xff09; ls file * ? 匹配任何一个字符&#xff08;不…

idea 的 springboot项目spring-boot-devtools 自动编译 配置热部署

1&#xff0c;设置一 2&#xff0c;设置二 设置二&#xff08;旧版本&#xff09; CtrlShiftAlt/ 点击弹出框中Registry... 引入&#xff08;如果报错&#xff0c;换不同的版本&#xff09; <dependency><groupId>org.springframework.boot</groupId><a…

Github拉取项目报错解决

前言 昨天在拉取github上面的项目报错了&#xff0c;有好几个月没用github了&#xff0c;命令如下&#xff1a; git clone gitgithub.com:zhszstudy/git-test.git报错信息&#xff1a; ssh: connect to host github.com port 22: Connection timed out fatal: Could not rea…

TypeScript 常用类型

文章目录 1. 类型注解2. 原始类型3. 数组类型4. 联合类型5. 类型别名6. 函数类型7. 对象类型8. 接口类型8.1 接口声明8.2 接口继承 9. 元组类型10. 类型断言11. 字面量类型12. 枚举类型12.1 数字枚举12.2 字符串枚举 13. any 类型14. typeof 运算符 1. 类型注解 前言&#xff1…

ARM200~500部署

前提&#xff1a;数据库已经安装好&#xff0c;并且正常运行 1.修改hostname,将里面的AR-A 改为hzx vi /etc/hostname 2.重启网络服务 sudo systemctl restart NetworkManager 3.修改community-admin.service 文件&#xff0c;更改小区名称和IP&#xff0c;并将文件上传到/…

Linux buildroot和ubuntu的异同点

Buildroot 和 Ubuntu 都是 Linux 系统的操作环境,但它们的设计理念和使用场景有很大的不同。 一、定义与目标 Buildroot Buildroot 是一个用于生成嵌入式 Linux 系统的工具集,专注于交叉编译和构建嵌入式设备的最小 Linux 环境。它的目标是为嵌入式系统提供定制化和优化的…

从0开始的opencv之旅(1)cv::Mat的使用

目录 Mat 存储方法 创建一个指定像素方式的图像。 尽管我们完全可以把cv::Mat当作一个黑盒&#xff0c;但是笔者的建议是仍然要深入理解和学习cv::Mat自身的构造逻辑和存储原理&#xff0c;这样在查找问题&#xff0c;或者是遇到一些奇奇怪怪的图像显示问题的时候能够快速的想…

免登录游客卡密发放系统PHP网站源码

源码介绍&#xff1a; 这是一个简单易用的卡密验证系统&#xff0c;主要功能包括&#xff1a; 卡密管理和验证&#xff0c;多模板支持&#xff0c;响应式设计&#xff0c;验证码保护&#xff0c;防刷机制&#xff0c;简洁的用户界面&#xff0c; 支持自定义模板&#xff0c;移…

LeetCode - 初级算法 数组(旋转数组)

旋转数组 这篇文章讨论如何通过编程实现数组元素的旋转操作。 免责声明:本文来源于个人知识与公开资料,仅用于学术交流。 描述 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 示例: 输入: nums = [1,2,3,

BOC调制信号matlab性能仿真分析,对比功率谱,自相关性以及抗干扰性

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a 3.部分核心程序 &#xff08;完整版代码包含详细中文注释和操作步骤视频&#xff09…

【从零开始入门unity游戏开发之——C#篇41】C#迭代器(Iterator)——自定义类实现 foreach 操作

文章目录 前言一、什么是迭代器&#xff1f;二、标准迭代器的实现方法1、自定义一个类CustomList2、让CustomList继承IEnumerable接口3、再继承IEnumerator接口4、完善迭代器功能5、**foreach遍历的本质**&#xff1a;6、在Reset方法里把光标复原 三、用yield return语法糖实现…

WordPress新安装只安装主题后发现只有首页能打开,其他路由页面都是404,并且Elementor都打不开

找到wordpress安装路径的这个文件&#xff0c;有发现里面没有内容&#xff0c;添加下面内容保存&#xff0c;重启服务器即可 # BEGIN WordPress <IfModule mod_rewrite.c> RewriteEngine On RewriteBase / RewriteRule ^index\.php$ – [L] RewriteCond %{REQUEST_FILEN…

uniapp中使用ruoyiPlus中的加密使用(crypto-js)

package.json中添加 "crypto-js": "^4.2.0", "jsencrypt": "^3.3.2",但是vue2中使用 import CryptoJS from cryptojs; 这一步就会报错 参照 参照这里&#xff1a;vue2使用CryptoJS实现信息加解密 根目录下的js文档中新增一个AESwork.…

无需训练!多提示视频生成最新SOTA!港中文腾讯等发布DiTCtrl:基于MM-DiT架构

文章链接&#xff1a;https://arxiv.org/pdf/2412.18597 项目链接&#xff1a;https://github.com/TencentARC/DiTCtrl 亮点直击 DiTCtrl&#xff0c;这是一种基于MM-DiT架构的、首次无需调优的多提示视频生成方法。本文的方法结合了新颖的KV共享机制和隐混合策略&#xff0c;使…

RabbitMQ基础篇之快速入门

文章目录 一、目标需求二、RabbitMQ 控制台操作步骤1.创建队列2.交换机概述3.向交换机发送消息4.结果分析5.消息丢失原因 三、绑定交换机与队列四、测试消息发送五、消息查看六、结论 一、目标需求 新建队列&#xff1a;创建 hello.queue1 和 hello.queue2 两个队列。消息发送…

ESP32S3 + IDF 5.2.2 扫描WiFi

ESP32S3 IDF 5.2.2 扫描WiFi 目录 1 资料 2 通过Wi-Fi库扫描附近的网络 2.1 通过idf命令创建工程 2.2 编写测试用例 2.3 优化测试用例 3 小结 1 资料 在ESP平台基于IDF开发WiFi相关功能&#xff0c;主要就是基于IDF的Wi-Fi库进行二次开发。可供参考的官方资料&#xff…

2025-1-2-sklearn学习(30)模型选择与评估-验证曲线: 绘制分数以评估模型 真珠帘卷玉楼空,天淡银河垂地。

文章目录 sklearn学习(30) 模型选择与评估-验证曲线: 绘制分数以评估模型30.1. 验证曲线30.2. 学习曲线 sklearn学习(30) 模型选择与评估-验证曲线: 绘制分数以评估模型 文章参考网站&#xff1a; https://sklearn.apachecn.org/ 和 https://scikit-learn.org/stable/ 每种估…