数据库基础-函数&约束

目录

一:数值函数

二:日期函数

三:流程函数

四:约束

约束演示

外键约束

语法


一:数值函数

常见的数值函数:

取绝对值: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;

相关推荐
陌上丨8 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56788 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw8 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30738 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道9 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据10 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务10 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯11 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七12 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草12 小时前
redis-9-哨兵
数据库·redis·bootstrap