MySQL入门:DCL数据控制语言(管理用户,权限控制),MySQL函数(字符串,数值,日期,流程)

目录

1.DCL(数据控制语言)

DCL英文全称是Data ControlLanguage(数据控制语言),用来管理数据库用户、控制数据库的访问权限。

1.管理用户

1.查询用户

sql 复制代码
USE mysql;
SELECT * FROM user;

2.创建用户

sql 复制代码
CREATE USER '用启名'@'主机名' IDENTIFIED BY '密码';

3.修改用户密码

sql 复制代码
ALTER USER '用户名'@'主机名' IDENTIFIED WITH mysql_native_password BY '新密码';

4.删除用户

sql 复制代码
DROP USER'用户名'@'主机名';

注意:

  • 主机名可以使用%通配
  • 这类SQL开发人员操作的比较少,主要是DBA ( Database Administrator数据库管理员)使用

2.权限控制

1.查询权限

sql 复制代码
SHOW GRANTS FOR '用户名'@'主机名';

2.授予权限

sql 复制代码
GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';

3.撤销权限

sql 复制代码
REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名';

注意:

  • 多个权限之间,使用逗号分隔
  • 授权时,数据库名和表名可以使用*进行通配,代表所有

2.函数

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

1.字符串函数

演示:

sql 复制代码
-- concat
select concat('hello ', 'MySQL');
-- lower
select lower('Hello');
-- upper
select upper('hello');
-- lpad
select lpad('01', 5, '-');
-- rpad
select rpad('01', 5, '-');
-- trim
select trim(' Hello  MySQL ');
-- substring
select substr('Hello MySQL',1,5);

2.数值函数

演示:

sql 复制代码
-- ceil 向上取整
select ceil(1.1);
-- floor 向下取整
select floor(1.9);
-- mod 取模
select mod(6,4);
-- rand 随机数
select rand();
-- round 四舍五入
select round(2.3444,2);

3.日期函数

演示:

sql 复制代码
-- 当前日期
select current_date();
-- 当前的时间
select current_time();
-- 当前日期加时间
select now();
-- 获取当前年
select YEAR(NOW());
-- 获取当前月
select MONTH(NOW());
-- 获取当前天
select DAY(NOW());
-- 往后推自然数天之后的日期
select date_add(now(), interval 50 day);
-- 两个指定日期之间相差的天数
select datediff('2024-03-01', '2024-1-12');

4.流程函数

演示:

sql 复制代码
-- if 判断真假
select if(false, 'Ok', 'Error');
-- 判断是否为空
select IFNULL('Ok', 'Default'); # ok
select IFNULL('', 'Default'); # ''
select IFNULL(null, 'Default');# Default
-- case when then else
select employee.name,
       (case employee.work_address
            when '北京' then '一线城市'
            when '上海' then '一线城市'
            else '二线城市' end) as '工作地址'
from employee;
相关推荐
liang_jy3 小时前
Android 窗口容器树(一)—— 窗口和窗口容器树
android·源码
HUGu RGIN3 小时前
MySQL--》如何在MySQL中打造高效优化索引
android·mysql·adb
HackTwoHub5 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t5 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK5 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)5 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Joseph Cooper6 小时前
Linux/Android 跟踪技术:ftrace、TRACE_EVENT、atrace、systrace 与 perfetto 入门
android·linux·运维
空中海6 小时前
安卓逆向03. 动态调试、抓包分析与 Frida Hook
android
S1998_1997111609•X7 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
一起搞IT吧7 小时前
相机Camera日志实例分析之二十:相机Camx【照片后置4800/5000/6400万拍照】单帧流程日志详解
android·嵌入式硬件·数码相机·智能手机