MySQL基础定期复盘

1.基本对于数据库及数据表的管理操作:

(1)创建库:CREATE DATABASE 名字;

(2)创建表:CREATE TABLE 名字(

字段名1 数据类型1 (PRIMARY KEY/NOT NULL/CHECK(约束条件)/DEFAULT (默认值)/UINIQUE)(AUTO_INCREMENT)/(ON UPDATE CASCODE ON DELETE SET NULL) ,

字段名2 数据类型2 ...,

字段名3 数据类型3 ....,

字段名4 数据类型4....,

CONSTRAINT 别名 FOREIGN KEY(外键) REFERENCES 主键所在表(主键),

CONSTRAINT 别名 UNIQUE(设置唯一约束的字段);

)

(3)修改字段名:ALTER TABLE 表名

CHANGE 原来的字段名 现在的字段名 数据类型;

(3)修改字段的数据类型:

ALTER TABLE 表名

CHANGE 字段名 字段名 新的数据类型 / MODIFY 字段名 新的数据类型;

(4)新设置约束

ALTER TBALE 表名

ADD CONTRAINT PRIMARY/FOREIGN KEY();

(5)删除字段

ALTER TABLE 表名

DROP 字段名;

(6)插入数据

INSERT INTO 表名 (字段名)VALUES(数据)

(7)删除数据

DELETE FROM 表名 WHERE 字段名

(8)修改数据

UPDATE 表名 SET 修改数据 WHERE 过滤条件

2.MODIFY使用时记得带着约束,因为除了主键、外键、唯一约束外,其他约束在使用MODIFY如果带着就会被重置,主键、外键、唯一约束创建索引;

3.连表查询

分为内联和外联,通过使用(RIGHT/LEFT)JOIN ON来实现

4.查询的整体的流程顺序:

SELECT...

FROM ... JOIN ...

ON ...

WHERE...

GROUP BY...

HAVING...

ORDER BY....ASC/DESC

LIMIT...

5.子查询可以按照行数分为单行子查询和多行自查询

也可以按照是否在子查询中有着和主查询相关键值分为相关子查询和非相关子查询;

单行子查询使用单行匹配符<,>,+,<>进行操作,多行自查询通过使用IN,ANY,ALL进行操作

6.常用的函数

(1)流程控制函数:IF(表达式,值1,值2);

IFNULL(值1,值2);

CASE WHEN ...THEN...ELSE...END

CASE 字段名 WHEN ... THEN ...ELSE...END

(2)日期操作函数:

YEAR(date),MONTH(date),DAY(date)...:获取指定单位的时间;

EXTEACT(type FROM date):也是获取指定单位的时间;

DATE_ADD/SUB_ADD(起始时间 INTERVAL type 时间):在基准时间上加或减时间;

DATE_FORMATE/TIME_FORMATE(date,format):格式化时间

STR_TO_DATE(str,fmt):字符串转时间

DATEDIFF(date1,date2):返回date1,date2间隔天数,date1需要大于date2;

TIMEDIFF(time1,time2):返回time1,time2间隔时间,t1>t2;

相关推荐
GBASE19 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满8782 天前
5.Mysql事务隔离级别与锁机制
mysql
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H3 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql