数据库基础-函数&约束

目录

一:数值函数

二:日期函数

三:流程函数

四:约束

约束演示

外键约束

语法


一:数值函数

常见的数值函数:

取绝对值:abs

演示如下:

A. ceil:向上取整

select ceil(1.1);

B. floor:向下取整

select floor(1.9);

C. mod:取模

select mod(7,4);

D. rand:获取随机数

select rand();

E. round:四舍五入

select round(3.99);

F. abs:取绝对值

select abs(-10);

二:日期函数

常见的日期函数:

演示如下:

A. curdate:当前日期

select curdate();

B. curtime:当前时间

select curtime();

C. now:当前日期和时间

select now();

D. YEAR , MONTH , DAY:当前年、月、日

select YEAR(now());

select MONTH(now());

select DAY(now());

列:select year(now()),month(now()),day(now());

E. date_add:增加指定的时间间隔

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

列:select date_add(now(),interval 3 day);

F. datediff:获取两个日期相差的天数

select datediff('2025-4-4', 'now()');

列:select DATEDIFF('2025-4-4',now());

三:流程函数

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

演示如下:

if:

select if(1=1,1,2);

ifnull

select ifnull(null,0);(如果返回值为空,返回0)

select ifnull(2,0);(如果返回值不为空,返回2)

case when (分两种表达)

第一种:select case 'a'

when 'a' then 1

when 'b' then 2

else 3

end;

第二种:select case

when 'a'='a' then 1

when 'b'='b' then 2

else 3

end;

查询emp表的员工工作地址 (北京/上海 ----> 一线城市 , 其他 ----> 二线城市)

select * ,

case

when workaddress in('北京','上海') then '一线城市'

else '二线城市'

end

from emp;

四:约束

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。目的:保证数据库中数据的正确、有效性和完整性。

分类:

约束演示

案列需求:

外键约束

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

语法

添加外键

案例:

为emp表的dept_id字段添加外键约束,关联dept表的主键id。

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);

删除外键

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

案例:

删除emp表的外键fk_emp_dept_id。

alter table emp drop foreign key fk_emp_dept_id;

相关推荐
数智化管理手记2 小时前
精益生产中的TPM管理是什么?一文破解设备零故障的密码
服务器·网络·数据库·低代码·制造·源代码管理·精益工程
翊谦3 小时前
Java Agent开发 Milvus 向量数据库安装
java·数据库·milvus
難釋懷3 小时前
OpenResty实现Redis查询
数据库·redis·openresty
别抢我的锅包肉4 小时前
【MySQL】第四节 - 多表查询、多表关系全解析
数据库·mysql·datagrip
Database_Cool_4 小时前
OpenClaw-Observability:基于 DuckDB 构建 OpenClaw 的全链路可观测体系
数据库·阿里云·ai
刘~浪地球4 小时前
Redis 从入门到精通(五):哈希操作详解
数据库·redis·哈希算法
zzh0815 小时前
MySQL高可用集群笔记
数据库·笔记·mysql
Shely20175 小时前
MySQL数据表管理
数据库·mysql
爬山算法5 小时前
MongoDB(80)如何在MongoDB中使用多文档事务?
数据库·python·mongodb
APguantou6 小时前
NCRE-三级数据库技术-第2章-需求分析
数据库·需求分析