Mysql数据库与数据库三大范式

作者:左新宇
链接:https://zhuanlan.zhihu.com/p/59394493
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
 

MySQL 常用命令

1.1 连接 MySQL

mysql –uroot –p

mysql –uroot -proot

1.2 查看当前所有的数据库

show databases;

1.3 创建数据库

create database 数据库名;

1.4 使用(切换)数据库

use 数据库名;

1.5 查看当前数据库的所有表格

show tables;

1.6 退出

exit;

oracle数据库与mysql数据库的区别

一、MySQL数据库的特点:

1、MySQL是关系型数据库管理系统

2、体积小,灵活性强,速度快

3、源码开放,成本低,可移植性强

二、与oracle数据库的区别

1、数值类型不同

a)整数类型包括:smallint(2字节),int(4字节),Integer(int同义词),bigint(8字节)

b)浮点数类型包括:float(4字节),double(8字节)

oracle数值类型只有:number

2、字符类型不同

MySQL有:char(定长),varchar(不定长)

oracle有:char(定长),varchar2(不定长)

3、日期时间类型不同

MySQL包括:date(yy-mm-dd),datetime(yyyy-mm-dd hh:mi:ss),time(hh:mi:ss),timestamp(更精确),year(yyyy)

oracle包括:date(yy-mm-dd hh:mi:ss),timestamp(更精确)

4、其他类型

MySQL包括:blob(存放二进制文件),text(存放大量文本信息)

oracle包括:blob(存放二进制文件),clob(存放大数据文件)

SQL语句上的区别

1、oracle的delete语法中from可以省略,但是MySQL中不能

2、MySQL中只能使用SQL99版本的语法,而oracle可以使用99和92版本的

3、分页查询中MySQL要使用limit,比较简单,而oracle使用rownum,较繁琐。

数据库三大范式

• 什么是范式(NF= NormalForm)

范式是符合某一种设计要求的总结。

要想设计一个结构合理的关系型数据库,必须满足一定的范式。

各范式特点:

第一范式:保证列的原子性,保证列不可再分。

第二范式:唯一性 ;一个表只说明一个事物;有主键且非主键依赖主键;(限制多对多的关系,建立一个关联表,通过外键和联合主键来关联两张表)

第三范式:每列都与主键有直接关系,不存在传递依赖;(限制一对多的关系,在从表中建立一个外键,通过外键来引用主表的信息)

PS:第二范式要遵循第一范式,第三范式要遵循第二范式。

1、不符合第一范式的例子(关系数据库中create不出这样的表):

表:姓名,性别,电话

问题:若某个人有两个电话,家庭电话和手机,这样则不符合第一范式。

解决:把电话列分成两个列即可。

2、不符合第二范式的例子:

表:学号, 姓名, 年龄, 课程名称, 成绩, 学分;

这个表明显说明了两个事务:学生信息, 课程信息,不符合第二范式。

存在问题:数据冗余,每条记录都含有相同信息。

解决:分成学生表和课程表分别存储即可。

3、不符合第三范式的例子:

学号, 姓名, 年龄, 所在学院, 学院联系电话,关键字为单一关键字"学号";

存在依赖传递: (学号) → (所在学院) → (学院地点, 学院电话)

存在问题:

数据冗余:有重复值;

解决:分成学生表,学院表即可。

例:

case when

场景:当需要从数据源上直接判断数据显示带不动含义的时候,就可以在SQL语句中使用case when 函数。

Case具有两种格式。简单Case函数和Case搜索函数。

--简单Case函数

CASE sex
WHEN '1' THEN '男'
WHEN '2' THEN '女'
ELSE '其他' END

--Case搜索函数

CASE WHEN sex = '1' THEN '男'
WHEN sex = '2' THEN '女'
ELSE '其他' END


这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。
还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。

--比如说,下面这段SQL,你永远无法得到“第二类”这个结果

CASE WHEN col_1 IN ( 'a', 'b') THEN '第一类'
WHEN col_1 IN ('a')       THEN '第二类'
ELSE'其他' END


下面我们来看一下,使用Case函数都能做些什么事情。

一,已知数据按照另外一种方式进行分组,分析。

有如下数据:(为了看得更清楚,我并没有使用国家代码,而是直接用国家名作为Primary Key)


根据这个国家人口数据,统计亚洲和北美洲的人口数量。应该得到下面这个结果。


想要解决这个问题,你会怎么做?生成一个带有洲Code的View,是一个解决方法,但是这样很难动态的改变统计的方式。
如果使用Case函数,SQL代码如下:

SELECT  SUM(population),
CASE country
WHEN '中国' THEN '亚洲'
WHEN '印度' THEN '亚洲'
WHEN '日本' THEN '亚洲'
WHEN '美国' THEN '北美洲'
WHEN '加拿大' THEN '北美洲'
WHEN '墨西哥' THEN '北美洲'
ELSE '其他' END
FROM    Table_A
GROUP BY CASE country
WHEN '中国' THEN '亚洲'
WHEN '印度' THEN '亚洲'
WHEN '日本' THEN '亚洲'
WHEN '美国' THEN '北美洲'
WHEN '加拿大' THEN '北美洲'
WHEN '墨西哥' THEN '北美洲'
ELSE '其他' END;


同样的,我们也可以用这个方法来判断工资的等级,并统计每一等级的人数。SQL代码如下;

SELECT
CASE WHEN salary <= 500 THEN '1'
WHEN salary > 500 AND salary <= 600  THEN '2'
WHEN salary > 600 AND salary <= 800  THEN '3'
WHEN salary > 800 AND salary <= 1000 THEN '4'
ELSE NULL END salary_class,
COUNT(*)
FROM    Table_A
GROUP BY
CASE WHEN salary <= 500 THEN '1'
WHEN salary > 500 AND salary <= 600  THEN '2'
WHEN salary > 600 AND salary <= 800  THEN '3'
WHEN salary > 800 AND salary <= 1000 THEN '4'
ELSE NULL END;


二,用一个SQL语句完成不同条件的分组。

有如下数据


按照国家和性别进行分组,得出结果如下


普通情况下,用UNION也可以实现用一条语句进行查询。但是那样增加消耗(两个Select部分),而且SQL语句会比较长。
下面是一个是用Case函数来完成这个功能的例子

 

SELECT country,
SUM( CASE WHEN sex = '1' THEN
population ELSE 0 END),  --男性人口
SUM( CASE WHEN sex = '2' THEN
population ELSE 0 END)   --女性人口
FROM  Table_A
GROUP BY country;

 还有就是这我总结出了一些架构视频资料和互联网公司java程序员面试涉及到的绝大部分面试题和答案做成了文档和架构视频资料还有完整高清的java进阶架构学习思维导图免费分享给大家(包括Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并发等架构技术资料),希望能帮助到您面试前的复习且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。 资料领取方式:关注 私信关键字【资料】即可免费获取!!!

如果您喜欢本文章,可以点击关注,每天将有更多精彩文章与您分享!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值