Bootstrap

MySQL之数据类型、建表、以及约束

目录

一、1.CRUD

SELECT(查询)

INSERT(新增)

UPDATE(修改)

DELETE(删除)

二、函数

常见函数

流程控制函数

聚合函数

三、union与union all

概念

语法

专业词解释

使用场景

示例

​四、思维导图


一、1.CRUD

SELECT(查询)

概念

查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作,

含义

“[“<字段列名>)包含星号通配符的字段列表,表示所要查询字段的名称

<表 1>,c表 2>...”,表 1和表 2 表示查询数据的来源,可以是单个或多个

WHERE<表达式>是可选项,如果选择该项,将限定查询数据必须满足该查询条件

GROUP BY< 字段>,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组

ORDER BY< 字段 才,该子句告诉 MySQL 按什样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序

LIMIT[coffset>,]crow count],该子句告诉 MySQL 每次显示查询出来的数据条数

INSERT(新增)

概念

使用INSERT 语向数据库已有的表中插入一行或者多行元组数据

语法

INSERTINTO <表名>[<列名1>[,...<列名n>]]INSERT...VALUES语句VALUES (值1)[...,(值n)];

含义

<表名>:指定被操作的表名。

<列名>:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 NSERT<表名>VALUES(..)即可

VALUES或VALUE子句:该子包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应

UPDATE(修改)

语法

UPDATE<表名> SET 字段 1=值 1[,字段 2=值 2...][WHERE 子句][ORDER BY 子句][LIMIT 子句]

含义

“SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT表示列值。

WHERE子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行

ORDER BY子句:可选项。用于限定表中的行被修改的次序

LIMIT子句:可选项。用于限定被修改的行数。

DELETE(删除)

语法

DELETE FROM<表名>[WHERE 子][ORDER BY 子][LIMIT 子句]

<表名>:指定要删除数据的表名

ORDER BY子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除

WHERE子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行

LIMIT”子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

二、函数

常见函数

字符函数

转小写 LOWER('SQL Course')   sql course

转大写 UPPER('SQL Course')    SQL COURSE

拼接 CONCAT('HelloWorld')    HelloWorld

截取  SUBSTR('HelloWorld,1,5')   Hello

长度  LENGTH('HelloWorld')  10

字符出现索引值  INSTR('HelloWorld’,'W')  6

字符截取后半段  TRIM('H' 'FROM' 'HelloWorld')  elloWorld

字符替换  REPLACE('abcd.b','m')  amcd

数字函数

四舍五入 ROUND(45.926,2)  45.93

截断  TRUNC(45.926,2)  45.92

日期函数

获取当前日期  now0

将日期格式的字符转换成指定格式的日期  - STR_TO DATE(9-13-1999 %m-%d-%Y)  1999-09-13

将日期转换成字符  DATEFORMAT(2018/6/6.%Y年%m月%d日)  2018年06月06日

流程控制函数

语法

CASE expr WHEN comparison_expr1 THEN return_expr1
[WHEN comparison expr2 THEN return_expr2WHEN comparison exprn THEN return exprnELSE else expr]
END

01)查询同时存在”01“课程和”02“课程的情况

SELECT
t3.*
(CASE WHEN t1.cid =01' THEN t1.score END) 语文
(CASE WHEN t2.cid =02' THEN t2score END) 数学
FROM
( SELECT*FROM t_mysql score sc WHERE sc.cid =01')t1,
( SELECT*FROM t_mysql_score sc WHERE sc.cid =02' )t2,
t_mysql_student t3
WHERE
t1.sid = t2.sid
AND t1.sid = t3.sid

聚合函数

sum 求和、avg 平均值、max 最大值、min 最小值、count 计算个数

三、union与union all

概念

UNION:用于合并两个或多个SELECT语句的结果集,并去除重复的行UNION ALL:用于合并两个或多个SELECT语句的结果集,包括重复的行。

语法

UNION:将多个SELECT语句放在一起,并使用UNION关键字将它们连接起来。每个SELECT语句的列数、列名和数据类型必须相同。
UNION ALL:将多个SELECT语向放在一起,并使用UNION ALL关键字将它们连接起来。每个SELECT语句的列数、列名和数据类型可以不同。

专业词解释

UNION:UNION操作符执行去除重复行的操作,它通过对所有的结果集进行排序和比较来实现
UNION ALL:UNION ALL操作符不执行去除重复行的操作,它直接将所有的结果集合并在一起。

使用场景

UNION:当需要合并多个查询结果,并且不希望出现重复行时,可以使用UNION操作符。它适用于数据需要去重的情况。
UNION ALL:当需要合并多个查询结果,包括重复行时,可以使用UNION ALL操作符。它适用于不需要去重的情况,或者在已经确定结果不会有重复行的情况下

示例

全列

初始数据

UNION

UNION all

四、思维导图

;