【从删库到跑路】详细讲解MySQL的函数和约束作用

🎊专栏【MySQL】
🍔喜欢的诗句:更喜岷山千里雪 三军过后尽开颜。
🎆音乐分享【如愿】
大一同学小吉,欢迎并且感谢大家指出我的问题🥰

文章目录

  • 🍔函数
    • ⭐字符串函数
      • 🎈字符串拼接函数
      • 🎈把字符串全部变为小写
      • 🎈把字符串全部变为大写
      • 🎈字符串左填充
      • 🎈字符串右填充
      • 🎈去掉字符串头部和尾部的空格
      • 🎈字符串截取
        • 🏀应用
    • ⭐数值函数
      • 🎈向上取整
      • 🎈向下取整
      • 🎈返回x/y的模
      • 🎈求随机数
      • 🎈四舍五入,并且保留n位小数
        • 🏀应用
    • ⭐日期函数
      • 🎈返回当前日期
      • 🎈返回当前时间
      • 🎈返回当前日期+时间
      • 🎈获取指定date的年份
      • 🎈获取指定date的月
      • 🎈获取指定date的天
      • 🎈返回一个时间,是date向后推迟number个DAY(或MONTH,YEAR)
      • 🎈两个指定时间中相差的天数
        • 🏀应用
    • ⭐流程控制函数
      • 🎈进行判断
      • 🎈如果第一个值为null,那么返回第二个值,否则返回第一个值
      • 🎈case语句
  • 🍔约束
      • 🎈主键约束
      • 🎈唯一约束
      • 🎈外键约束
        • 🏀添加外键
        • 🏀删除外键
      • 🎈检测约束
      • 🎈非空约束
        • 🏀样例
    • ⭐总结

在这里插入图片描述

🍔函数

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

⭐字符串函数

在这里插入图片描述

🎈字符串拼接函数

concat('s1','s2');

在这里插入图片描述

🎈把字符串全部变为小写

select lower('str');

在这里插入图片描述

🎈把字符串全部变为大写

select upper('str');

在这里插入图片描述

🎈字符串左填充

select lpad('str',length,'-');
 -- 在str左边用-进行填充,达到长度为n

在这里插入图片描述

🎈字符串右填充

select rpad('str',length,'-');
 -- 在str右边用-进行填充,达到长度为n

在这里插入图片描述

🎈去掉字符串头部和尾部的空格

select trim('str');

在这里插入图片描述

🎈字符串截取

select substring('str',截取起始位置,截取长度);

在这里插入图片描述

🏀应用

由于业务需求变化,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0
(比如1好员工的工号应该是00001)

update emp set worknumber = lpad(worknumber,5,'0');
 --            更新的字段(工号)

⭐数值函数

在这里插入图片描述

🎈向上取整

select ceil(number);

在这里插入图片描述

🎈向下取整

select floor(number);

在这里插入图片描述

🎈返回x/y的模

select mod(num1,num2);

在这里插入图片描述

🎈求随机数

是0~1之间的随机数

select rand();

在这里插入图片描述

🎈四舍五入,并且保留n位小数

对number进行四舍五入,并且保留length位小数

select round(number,length);

在这里插入图片描述

🏀应用

通过数据库的函数,生成一个六位数的随机验证码

select lpad(round()*1000000,0),6,'0');

⭐日期函数

在这里插入图片描述

🎈返回当前日期

select curdate();

在这里插入图片描述

🎈返回当前时间

select curtime();

在这里插入图片描述

🎈返回当前日期+时间

select now();

在这里插入图片描述

🎈获取指定date的年份

select YEAR(date);

在这里插入图片描述

🎈获取指定date的月

select MONTH(date);

在这里插入图片描述

🎈获取指定date的天

select DAY(date);

在这里插入图片描述

🎈返回一个时间,是date向后推迟number个DAY(或MONTH,YEAR)

select date_add(now(),INTERVAL 70 MONTH);

在这里插入图片描述

🎈两个指定时间中相差的天数

select datediff('2021-12-01','2022-12-01');

在这里插入图片描述

🏀应用

查询所有员工的入职天数,并根据入职天数倒序排序

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

解释:entrydays是函数的别名,这样子就不用写一串函数了,order by 后面的是排序方式

⭐流程控制函数

在这里插入图片描述

🎈进行判断

如果条件表达式的结果是true,那么返回OK,否则返回Error

select if(条件表达式,'OK','Error');

在这里插入图片描述

🎈如果第一个值为null,那么返回第二个值,否则返回第一个值

select ifnull('OK','Default');

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

🎈case语句

select 
     name,
     ( case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end )
 
 from emp;

🍔约束

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据
目的:保证数据库中数据的正确,有效性和完整性
分类:
在这里插入图片描述

🎈主键约束

主键约束(Primary Key Constraint):主键约束用于定义一个唯一标识来标识表中的每一行。它要求主键列的值唯一且非空。主键可以由一个或多个列组成。

"column"是指表中的一个字段,"datatype"是数据类型

CREATE TABLE table_name (
    column1 datatype,
    column2 datatype,
    ...
    primary key (column1, column2, ...)
);

🎈唯一约束

唯一约束(Unique Constraint):唯一约束用于确保表中的某个列或一组列的值是唯一的。唯一约束允许空值(NULL),但对于非空值,要求其在列中是唯一的。

"column"是指表中的一个字段,"datatype"是数据类型

CREATE TABLE table_name (
    column1 datatype,
    column2 datatype,
    ...
    unique (column1, column2, ...)
);

🎈外键约束

外键约束(Foreign Key Constraint):外键约束用于建立表与表之间的关联关系。用来让两张表之间建立连接,从而保证数据的一致性和完整性

在这里插入图片描述

"column"是指表中的一个字段,"datatype"是数据类型

🏀添加外键

情况1:表结构没有创建好(直接在表里面进行添加)


CREATE TABLE table_name2 (
    column1 datatype primary key,
    column2 datatype,
    ...
    foreign key (column2) references table_name1(column1)
);

情况2:表结构创建好了

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

🏀删除外键

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

🎈检测约束

检查约束(Check Constraint):检查约束用于限制列中的值必须满足指定的条件。可以使用逻辑运算符、比较运算符和函数等来定义检查约束条件。

"column"是指表中的一个字段,"datatype"是数据类型

CREATE TABLE table_name (
    column1 datatype,
    column2 datatype check (condition),
    ...
);

🎈非空约束

非空约束(Not Null Constraint):非空约束用于确保表中的某个列不接受空值(NULL)。

"column"是指表中的一个字段,"datatype"是数据类型

CREATE TABLE table_name (
    column1 datatype not null,
    column2 datatype,
    ...
);

🏀样例

create table user(
     id int primary key auto_increment comment '主键',
     name varchar(10) not null unique comment '姓名',
     age int check ( age > 0 && age < 30 ) comment '年龄',
     status char(1) default '1' comment '状态',
     gender char(1) comment '性别'
 ) comment '用户表';

插入数据

insert into user(name,age,status,gender) values ('Tom1','19','1','男'),('Tom2','25','0','男');

⭐总结

在这里插入图片描述

🥰如果大家有不明白的地方,或者文章有问题,欢迎大家在评论区讨论,指正🥰

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

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

相关文章

LabVIEW开发呼吸分析系统

LabVIEW开发呼吸分析系统 在日常生活中&#xff0c;许多人都在练习调息法&#xff0c;但大多数人都不知道如何以完美的方式做。不当的做法不会带来适当的结果。一种使用LabVIEW分析呼吸信号的方法&#xff0c;以使人们以完美的方式练习调息。这有助于从业者按照系统指定的说明…

Vue2封装一个全局通知组件并发布到NPM

✍&#x1f3fc;作者&#xff1a;周棋洛&#xff0c;计算机学生 ♉星座&#xff1a;金牛座 &#x1f3e0;主页&#xff1a;点击查看更多 &#x1f310;关键&#xff1a;vue2 组件封装 npm发包 文章目录 1. 前言 &#x1f343;2. 我为什么要封装通知插件 ❓3. 初始化vue空项目 &…

Learn Mongodb DB数据库部署 ②

作者 : SYFStrive 博客首页 : HomePage &#x1f4dc;&#xff1a; PHP MYSQL &#x1f4cc;&#xff1a;个人社区&#xff08;欢迎大佬们加入&#xff09; &#x1f449;&#xff1a;社区链接&#x1f517; &#x1f4cc;&#xff1a;觉得文章不错可以点点关注 &#x1f44…

【STM32】软件I2C控制频率

在上一篇文章中&#xff0c;我们已经介绍了整个软件I2C的实现原理&#xff0c;但是也遗留了一个问题&#xff0c;那就是I2C速率的控制&#xff0c;其实就是控制SCL信号的频率。 微秒级延时 在上篇文章中&#xff0c;我们使用了SysTick进行延时&#xff0c;具体如下&#xff1…

Ubuntu下编译VTK

1.先安装QT&#xff0c;不知道不装行不行&#xff0c;我们项目需要。 2.去VTK官网下载VTK源码。 3.解压源码。 4.编译需要用cmake-gui&#xff0c;装QT的一般都有&#xff0c;但需要把路径添加到PATH才能用。 5.打开cmake-gui&#xff0c;设置源码路径&#xff0c;编译输出路…

Java开发 - Canal的基本用法

前言 今天给大家带来的是Canal的基本用法&#xff0c;Canal在Java中常被我们用来做数据的同步&#xff0c;当然不是MySQL与MySQL&#xff0c;Redis与Redis之间了&#xff0c;如果是他们&#xff0c;那就好办了&#xff0c;我们可以直接通过配置来完成他们之间的主从、主主&…

【SpringBoot】一、SpringBoot3新特性与改变详细分析

前言 本文适合具有springboot的基础的同学。 SpringBoot3改变&新特性 一、前置条件二、自动配置包位置变化1、Springboot2.X2、Springboot3.X 三、jakata api迁移1、Springboot2.X2、Springboot3.X3、SpringBoot3使用druid有问题&#xff0c;因为它引用的是旧的包 四 新特…

MySQL数据库--------简单理解文件的相关信息

作者前言 欢迎小可爱们前来借鉴我的gtiee秦老大大 (qin-laoda) - Gitee.com ———————————————————————————————————— 目录 文件的信息 文件的权限 权限的赋予 —————————————————————————————— 插播一些…

MySQL 备份与恢复

MySQL 备份与恢复 一、数据库备份的分类1.1 数据备份的重要性1.2 数据库备份的分类1.2.1 从物理与逻辑的角度&#xff0c;分为物理备份和逻辑备份1.2.2 从数据库的备份策略角度&#xff0c;分为完全备份&#xff0c;差异备份和增量备份1.2.3 常见的备份方法 二、MySQL完全备份与…

爬虫入门指南(1):学习爬虫的基础知识和技巧

文章目录 爬虫基础知识什么是爬虫&#xff1f;爬虫的工作原理爬虫的应用领域 爬虫准备工作安装Python安装必要的库和工具 网页解析与XPath网页结构与标签CSS选择器与XPathXpath 语法XPath的基本表达式&#xff1a;XPath的谓语&#xff08;Predicate&#xff09;&#xff1a;XPa…

【K8S系列】深入解析K8S存储

序言 做一件事并不难&#xff0c;难的是在于坚持。坚持一下也不难&#xff0c;难的是坚持到底。 文章标记颜色说明&#xff1a; 黄色&#xff1a;重要标题红色&#xff1a;用来标记结论绿色&#xff1a;用来标记一级论点蓝色&#xff1a;用来标记二级论点 Kubernetes (k8s) 是一…

elementui el-table-column表头换行,自定义表头以及排序图标的位置放置

目录 1、普通表头换行⭐️想实现以下效果 2、表头换行时调整文字和排序图标的位置⭐️想实现以下效果遇到问题 效果如下遇到问题 效果如下⭐️最终成功实现以下效果 &#x1f44d;写在最后 1、普通表头换行 https://www.jb51.net/article/228935.htm // 在需要换行的地方加入换…

开源虚拟化工具VirtualBox安装部署

什么是Virtualbox VirtualBox是一款由Oracle开发和维护的免费开源虚拟化软件&#xff0c;用于在一台计算机上创建和管理多个虚拟机。它允许用户在单个物理计算机上运行多个操作系统&#xff0c;例如Windows、Linux、macOS等。VirtualBox提供了一个虚拟化环境&#xff0c;使用户…

云原生(第二篇)k8s-二进制搭建

准备五台机器&#xff1a; master01&#xff1a;192.168.169.10 node01&#xff1a;192.168.169.40 node02&#xff1a;192.168.169.50 master02&#xff1a;192.168.169.60 负载均衡nginxkeepalive01&#xff08;master&#xff09;&#xff1a;192.168.169.20 负载均衡…

9.用python写网络爬虫,完结

前言 这是python网络爬虫的最后一篇给大家做个总结&#xff0c;且看且珍惜把&#xff01; 截止到目前&#xff0c; 前几章本书介绍的爬虫技术都应用于一个定制网站&#xff0c;这样可以帮助我们更加专注于学习特定技巧。而在本章中&#xff0c;我们将分析几个真实网站&#xff…

azure databricks因为notebook 日志打多或者打印图片太多,往下拉卡死怎么处理

1、同事碰到个问题&#xff0c;databricks 页面卡死不动了 2、我。。。。。。。。测试了下搞不定&#xff0c;找azure的工程师&#xff0c;特此笔记如下图 !](https://img-blog.csdnimg.cn/5db9756d0e224d15a9a607561b47591f.png)

2014年全国硕士研究生入学统一考试管理类专业学位联考逻辑试题——纯享题目版

&#x1f3e0;个人主页&#xff1a;fo安方的博客✨ &#x1f482;个人简历&#xff1a;大家好&#xff0c;我是fo安方&#xff0c;考取过HCIE Cloud Computing、CCIE Security、CISP、RHCE、CCNP RS、PEST 3等证书。&#x1f433; &#x1f495;兴趣爱好&#xff1a;b站天天刷&…

QT ObjectThread moveToThread多线程操作

QT多线程专栏共有15篇文章&#xff0c;从初识线程到、QMutex锁、QSemaphore信号量、Emit、Sgnals、Slot主线程子线程互相传值同步变量、QWaitCondition、事件循环、QObjects、线程安全、线程同步、线程异步、QThreadPool线程池、ObjectThread多线程操作、 moveToThread等线程操…

LeetCode 打卡day46-- 单词拆分和多重背包问题

一个人的朝圣 — LeetCode打卡第46天 知识总结 Leetcode 139. 单词拆分题目说明代码说明 知识总结 今天写了一道题目, 但是还挺难的, 而且是面试高频题目 还过了一遍多重背包问题. 多重背包与01背包的区别在于多重背包限制了物品的个数, 某些物品的个数可能不为1, 可以使用两…

c++day3

#include <iostream> using namespace std;class Person { private:int age;int *p; public://无参构造Person():p(new int(89)){age 18;cout << "无参构造函数" <<endl;}//有参构造Person(int age,int num){this->age age;this->pnew int…