【Java EE】Day03 DQL、约束、数据库设计、范式、备份和还原
〇、总结
1、DQL
- 聚合函数有空值需要使用ifnull函数
- where不能使用聚合函数
- 分页开始索引的计算,及mysql和oracle的方言
2、约束
- 删除唯一约束DROP INDEX 列名;
3、范式
- 2N范式消除部分依赖
4、备份与还原
- 数据库备份mysqld DB名>路径
- 数据库还原:source SQL文件
一、DQL查询语句
1、排序查询:order by
2、聚合函数
- 一列为一个整体,进行列的纵向计算
- 会排除空值项
- ifnull函数
3、分组查询
- group by子句 having xxx条件
- where中不能跟聚合函数而having可以
4、分页查询
- limit 开始索引,每页条数
- 公式 :开始的索引=(当前的页码-1)*每页显示的条数
- 方言:oracle是rownumber
二、约束
1、概述
- 对表中数据限定,保证其正确性
- 分类
- 主键约束
- 非空约束:not null
- 唯一约束
- 外键约束
2、非空约束
- 创建
- 修改:ALTER TABLE STU MODIFY NAME VARCHAR(20) NOT NULL;
- 删除:ALTER TABLE STU MODIFY NAME VARCHAR(20);-- 也是一种修改
3、唯一约束
- 改:ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
- 删:ALTER TABLE stu DROP INDEX phone_number;
4、主键约束
- 表中记录的唯一标识
- 改:ALTER TABLE STU MODIFY ID INT PRIMARY KEY;
- 删:
- ALTER TABLE STU MODIFY ID INT;-- 执行成功但不会生效
- ALTER TABLE STU DROP PRIMARY KEY;
- 主键自增长:auto_increment
-- 删除自动增长
ALTER TABLE STU MODIFY ID INT;
INSERT INTO STU VALUES(12,'CCC');-- 可以
INSERT INTO STU VALUES(NULL,'CCC');-- 不可以
-- 添加自动增长
ALTER TABLE STU MODIFY ID INT AUTO_INCREMENT;
INSERT INTO STU VALUES(NULL,'CCC');-- 可以
5、外键约束
- constraint 外键名称 foreign key 外键列名称 reference 主表名称(主表的列名称)
- 删:ALTER TABLE employee DROP FOREIGN KEY emp_dept_fk;
- 改:ALTER TABLE employee ADD CONSTRAINT emp_dept_fk FOREIGN KEY (dep_id) REFERENCES department(id);
- 级联操作
- 级联更新:ON UPDATE CASCADE;
- 级联删除:ON DELETE CASCADE;
三、数据库的设计
1、多表之间的关系
- 一对一
- 一对多
- 多对多
2、实现关系
- 一对一
- 一对多

- 多对多

- 避免多个外键值不指向同一个数据
- 解决:对外键列添加unique约束
3、案例:途牛旅游网

四、数据库设计范式
1、概述
- 设计数据库要遵循的规范
- 越高的范式冗余越小
- 共6种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)
2、分类
- 第一范式(1NF):不可分割的原子项。
- 第二范式(2NF):非码属性完全依赖于候选码(在1NF基础上消除非主属性对主码的部分函数依赖)
- 第三范式(3NF):非主属性不依赖于其它非主属性(在2NF基础上消除传递依赖)
3、范式详解
- 2NF
- 函数依赖
- 完全函数依赖,如(学号,课程名称)--->分数
- 部分函数依赖,如(学号,课程名称)-->姓名
- 3NF
- 消除传递依赖,解决下述添加问题

五、数据库的备份和还原
1、备份
- mysqldum -u用户名 -p密码 (数据库名)> 保存的路径
2、还原
- 步骤:
- 建库
- 使用
- 执行还原文件

3、图形化界面
【Java EE】Day03 DQL、约束、数据库设计、范式、备份和还原的更多相关文章
- Oracle笔记(十六) 数据库设计范式
数据库设计范式是一个很重要的概念,但是这个重要程度只适合于参考.使用数据库设计范式,可以让数据表更好的进行数据的保存,因为再合理的设计,如果数据量一大也肯定会存在性能上的问题.所以在开发之中,唯一可以 ...
- BCNF/3NF 数据库设计范式简介
数据库设计有1NF.2NF.3NF.BCNF.4NF.5NF.从左往右,越后面的数据库设计范式冗余度越低. 满足后一个设计范式也必定满足前一个设计范式. 1NF只要求每个属性是不可再分的,基本每个数据 ...
- 数据库设计范式1——三范式
一讲到数据库设计,大家很容易想到的就是三范式,但是第四.第五范式又是什么,不是很清楚,三范式到底怎么区分,也不清楚,作为数据库设计的基础概念,我再讲解下数据库范式. Normal form Bri ...
- 【HCIA Gauss】学习汇总-数据库管理(数据库设计 范式 索引 分区)-7
zsql user/pasword@ip:port -c "show databases" # 展示一条sql语句 spool file_path 指定输出文件 可以为相对路径 s ...
- MySql约束_设计_备份还原(资料二)
今日内容 1. DQL:查询语句 1. 排序查询 2. 聚合函数 3. 分组查询 4. 分页查询 2. 约束 3. 多表之间的关系 4. 范式 5. 数据库的备份和还原 DQL:查询语句 1. 排序查 ...
- MariaDB第三章:数据库设计与备份--小白博客
数据库设计 1.第一范式(确保每列保持原子性) 第一范式是最基本的范式.如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式. 2.第二范式(确保表中的每列都和主键相关) 第 ...
- MySQL 拷贝数据库表方式备份,还原后提示 table xxx '' doesn`t exist
MySQL很强大,支持直接拷贝数据库文件快速备份,那数据库文件在哪里呢? 打开MySQL的配置文件 my.ini,找到 datadir 节点,如 datadir="D:/Program Fi ...
- SQL Server 2008数据库创建,备份,还原图解及注意点
一.新建数据库 步骤1:点击“新建数据库”. 步骤2:输入数据库名称,设置数据库文件保存位置(注意点:最好自己设置数据库文件保存位置,不要采用安装时默认的文件保存位置!),点击“确认”即可完成新库的创 ...
- 数据库设计范式2——BC范式和第四范式
我在很久之前的一篇文章中介绍了数据库模型设计中的基本三范式,今天,我来说一说更高级的BC范式和第四范式. 回顾 我用大白话来回顾一下什么是三范式: 第一范式:每个表应该有唯一标识每一行的主键. 第二范 ...
- Java丨角色权限控制——数据库设计
相信各位读者对于角色权限管理这个需求并不陌生.那么是怎么实现的呢?今天小编来说道说道! 1.首先我们来进行数据库的设计,如何设计数据库是实现权限控制的关键: 1)用户表: id:主键.自增.int n ...
随机推荐
- 查找Linux下的大目录或文件
目录 du -h --max-depth=1 du -h --max-depth=2 | sort -n du -hm --max-depth=2 | sort -n du -hm --max-dep ...
- mysql8数据库修改root密码,以及创建用户遇到的坑,开启远程登录,用navicat进行mysql的远程连接,mysql8.0默认编码方式,部分参数配置查询命令
yum 安装MySQL8 echo "删除系统默认或之前可能安装的其他版本的 mysql" for i in $(rpm -qa|grep mysql);do rpm -e $i ...
- Redis一键安装脚本
#! /usr/bin/env bash # redis 6.0.3 源码安装 # 用法: bash -x install-redis-single.sh 6.0.3 version=$1 usage ...
- MyCLI :一个支持自动补全和语法高亮的 MySQL/MariaDB 客户端
MyCLI 是一个易于使用的命令行客户端,可用于受欢迎的数据库管理系统 MySQL.MariaDB 和 Percona,支持自动补全和语法高亮.它是使用 prompt_toolkit 库写的,需要 P ...
- 1_MySQL
一. 什么是数据库 概念: 数据库是按照数据结构来组织, 存储和管理数据的仓库, 是一个长期存储在计算机内的, 有组织的, 有共享的, 统一管理的数据集合 分类: 网状结构数据库: 美国通用汽车公司I ...
- Jupyter Notebook单元格加宽的方法3种
Jupyter Notebook的代码单元格比较窄,在我的屏幕上只占了一半都不到,网络搜索下,共找到3种加宽的方法,总结一下. (一)只改变当前Jupyter笔记本的单元格宽度 在Jupyter No ...
- springboot中使用mybatisplus自带插件实现分页
springboot中使用mybatisplus自带插件实现分页 1.导入mybatisplus分页依赖 <dependency> <groupId>com.baomidou& ...
- SpringBoot 2.5.5整合轻量级的分布式日志标记追踪神器TLog
TLog能解决什么痛点 随着微服务盛行,很多公司都把系统按照业务边界拆成了很多微服务,在排错查日志的时候.因为业务链路贯穿着很多微服务节点,导致定位某个请求的日志以及上下游业务的日志会变得有些困难. ...
- PHP + ELK实现日志记录
一个简单的PHP 文件 效果 full.conf文件 流程: 开启logstash服务之后. 在业务代码里面操作函数写入日志.log logstash通过实践戳获取到用户的变更,取出最后一行数据,发送 ...
- win10桌面右键卡顿卡死解决方法
win+R,打开命令行 输入services.msc 找到NADIA Display Container LS,将其由自动改为禁用,解决问题. PS:网上有些改注册表的方法,确实可以治标,但是大家都应 ...