项目一 分析并设计学生管理数据库

项目一 分析并设计学生管理数据库

1,做好管理数据库的知识准备

1.1,初识数据库

**1,DBMS:**数据库管理系统(Database Management System)。数据库 是通过DBMS创建和操作的

容器。

1.png

**2,DB:**数据库(database) :存储数据的“仓库”。它保存了一系列有组织的数据。

**3,SQL:**结构化查询语言(Structure Query Language) :专门用来与数据库通信的语言。

三者关系说明1700892475637_C3FDE2AC-49F3-4f91-AEEC-C25BEAD4B1E0.png

4,SQL分类:

  • 数据定义语句DDL:数据库对象的create,alter,drop操作
  • 数据查询语句DQL:select操作(可细分为单表查询、多表查询和子查询)
  • 数据操作语句DML:insert,update,delete操作
  • 数据控制语句DCL:数据安全管理,事务处理,指针控制操作

1.2,探索数据库的存储结构

主要部分:数据库,数据表,列,行,冗余,主键,外键,复合键,索引参照完整性

**1,数据库:**是一些关联表的集合。

**2,数据表:**table

image.png

**3,列(字段):**字段包含字段名和字段值。字段名及其特性是在创建表结构时定义的,而字段值是

在表创建完成后,向表中插入的数据。

**4,行(记录):**所有字段值的集合。

**5,冗余:**是指同一个数据在系统中多次重复出现。

**6,主键:**某些字段的特性,所取字段值必须唯一且不为空,用来标识表中的记录。一个数据表只能有一个主键

**7,外键:**用于关联两个表。

  • 一对一关系
  • 一对多关系image.png
  • 多对对关系

image.png

**8,索引:**类似于目录

2,设计一个规范的学生管理数据库

2.1,完成学生管理数据库的设计

实体-关系模型(E-R 图) 的三大要素是:实体、属性和关系。

利用 E-R 模型进行逻辑设计

  • E-R 模型中的实体映射为表
  • E-R 模型中的属性映射为表中的字段
  • E-R 模型中的关系映射为表间关系

2.2,时间数据库的规范化

范式越高数据库的冗余越小,数据库只要满足第三范式就行。

目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、 第四范式 4NF)和第五范式(5NF,又称完美范式)。

1,第一范式:字段具有原子性,不可分割。

**2,第二范式:**数据库表中的每个实例或记录必须可以被唯一地区分(标识)。选取一个能区分每个实体的属性或属性组,作为实体的唯一标识。非主属性(非主键字段)完全依赖于主属性(主键)

**3,第三范式:**要求一个关系表中不包含已在其它关系表已包含的非主关键字段。3NF 就是在 2NF 基础上消除传递依赖,使得表中所有字段都直接依赖于主键字段。

3,完成项目环境的搭建

MySQL 是一个轻量级、免费开源的关系型数据库管理系统。

3.1,准备一个安装包

**官网下载社区版:**https://dev.mysql.com/downloads/mysql/

1,选择社区版本

image.png

2,找到Windows版本

image.png

3,点击下载按钮

image.png

4,点击开始下载

image.png

3.2,安装并配置MySQL服务器

1,安装MySQL数据库

image.png

2,选择安装类型

image.png

3,选择存储和数据目录

image.png

4,点击Execute,检测需要的安装

image.png

5,检测完成,选择同意,点击安装,安装完需要的软件后点击关闭(目录中不能有中文。否则会出错)

image.png

6,点击下一步

image.png

7,点击Execute

image.png

8,点击下一步

image.png

9,点击下一步

image.png

10,点击下一步

image.png

11,设置密码,登录时用

image.png

12,点击下一步

image.png

13,点击下一步

image.png

14,点击Execute

image.png

15,点击下一步

image.png

16,登录Windows的MySQL

image.png

image.png

3.3,选择并使用Navicat客户端工具

本次选择的客户端图形化工具是 Navicat_for_MySQL_11.0.10。

1,快捷方式安装

image.png

2,正在安装

image.png

3,安装完成

image.png

4,连接MySQL服务器

image.png

image.png

3.4,做一个MySQL的目录结构清单

1,MySQL 安装成功后,将生成下面的目录结构。

image.png

  • bin 目录:用于存放一些可执行文件
  • docs 目录:用于放置一些文档
  • include 目录:用于放置一些头文件
  • lib 目录:用于放置一系列的库文件
  • share 目录:用于存放字符集、语言等信息
  • my-default.ini 文件:数据库中使用的配置文件。
  • data 目录是存放数据库文件和数据库信息的地方

4,小试牛刀

4.1,启动与停止MySQL服务

1.使用 Windows 服务管理器操作 MySQL 服务

点击此电脑->点击管理(出现下面图之后,右击即可找到想要的服务)

image.png

2.使用 DOS 命令操作 MySQL 服务

(1)在菜单中使用cmd命令,进入DOS窗口

image.png

(2)启动 MySQL 服务的命令:net start mysql

image.png

(3)停止 MySQL 服务的命令:net stop mysql57

image.png

4.2登录MySQL服务器

1.使用命令登陆

在 DOS 环境中使用 mysql 命令登陆,格式为:mysql -h 主机名或 IP 地址 -u 用户名 -p 用户密码

注意,在输入密码时字母 p 和后面的密码之间不能有空格,但是字母 h 和 u 后面可以有空格也可以没有。

设置环境变量的方法:

(1)右击此电脑->点击属性(找到高级网络设置)

image.png

(2)点击环境变量

image.png

(3)添加环境变量

image.png

(4)将bin目录的完整路径添加上(最后一直点确定退出即可)

image.png

设置好 MySQL 的 bin 目录的环境变量后,再进入 DOS 环境中,无论提示符的当前路径是什么都可以直接使用 mysql 命令了。

例1.1:输入完成的mysql命令

image.png

也可以将上面的 localhost 改为 127.0.0.1

mysql -h 127.0.0.1 -u root -pabcdef

例 1.2:如果登陆本机,可以省略主机名部分。

mysql -u root -pabcdef

2.使用 MySQL 5.7 Command Line Client – Unicode 登陆

上面已讲过

3.使用 Navicat for MySQL 登陆

image.png

image.png

4.3,给root用户修改登录密码

#1.使用 bin 目录下的 mysqladmin命令修改密码
格式:mysqladmin -u 用户名 -p 旧密码 password 新密码
例 1.3:将 root 用户的旧密码 abcdef 修改为新密码 6 个 a 。
mysqladmin -u root -pabcdef password aaaaaa

#2.进入 MySQL 的命令窗口后,使用 SET PASSWORD 命令修改密码
 SET PASSWORD FOR 用户名= PASSWORD('新密码');
例 1.4:将 root 用户的密码再改回为 abcdef 。
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('abcdef');
mysql> quit;
退出 MySQL 环境后,在 DOS 中输入 mysql 命令,使用新密码重新进入。
mysql -u root -pabcdef

#3.进入 MySQL 的命令窗口后,使用 UPDATE 语句修改密码
 mysql> use mysql;
 mysql> update user set authentication_string=password('abcdef') where user='root' and host='localhost';
 mysql> FLUSH PRIVILEGES;

**说明:**在 MySQL5.7 版本中,user 表中的密码字段名是 authentication_string,而且用户的密码是使用password 函数加密后存储在该字段中的。

4.4,开始使用常见命令

1,输入“help;”或者“\h”命令,此时会显示 MySQL 的帮助信息

image.png

2,可以使用 delimiter 命令修改默认的结束符

3,exit 和 quit 两个命令都是退出当前 MySQL 环境

4,status 命令查看当前 MySQL 服务器的信息

image.png

5,使用 use 命令可以选中某个数据库,使之成为当前操作的数据库。

word 函数加密后存储在该字段中的。

4.4,开始使用常见命令

1,输入“help;”或者“\h”命令,此时会显示 MySQL 的帮助信息

[外链图片转存中…(img-BSprYpxu-1702120035245)]

2,可以使用 delimiter 命令修改默认的结束符

3,exit 和 quit 两个命令都是退出当前 MySQL 环境

4,status 命令查看当前 MySQL 服务器的信息

[外链图片转存中…(img-L6Agxr3c-1702120035246)]

5,使用 use 命令可以选中某个数据库,使之成为当前操作的数据库。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/232739.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【数据结构第 6 章 ③】- 用 C 语言实现邻接表并简单介绍十字链表和邻接多重表

目录 一、邻接表 1.1 - ALGraph.h 1.2 - ALGraph.c 1.3 - Test.c 二、十字链表 三、邻接多重表 一、邻接表 邻接表(Adjacency List)是图的一种链式存储结构。在邻接表中,对图中每个顶点建立一个单链表,第 i 个单链表中的结…

用modelbox server启动流程图,暴露Restful接口

背景 假设你已经搭建了modelbox开发容器,能够使用webUI构建流程图。如果没有请参考昇腾npu上构建modelbox webUI开发容器教程。 现在,本文会说明,如何在终端用命令的方式将流程图暴露为服务,并能够在本地用postman访问。 本文参…

二分查找|双指针:LeetCode:2398.预算内的最多机器人数目

作者推荐 本文涉及的基础知识点 二分查找算法合集 滑动窗口 单调队列:计算最大值时,如果前面的数小,则必定被淘汰,前面的数早出队。 题目 你有 n 个机器人,给你两个下标从 0 开始的整数数组 chargeTimes 和 runnin…

java学习part41泛型

164-泛型-泛型的理解及其在集合、比较器中的使用_哔哩哔哩_bilibili 1.泛型 泛型可以加,加了不用也可以 2.例子 2.1List泛型 2.2Map泛型 新特性var 类似c的auto,可以根据后面赋值推断类型,在这种类型很复杂的时候可以提高可读性 3.自定义泛型…

什么是TDR(威胁检测与响应)

网络安全是被动和主动方法的混合体。过去,企业往往局限于被动的方法,随着合规性和安全策略越来越受到重视,主动方法也越来越受到关注。与其他行业相比,网络安全是高度动态的,网络安全团队采用任何可以帮助他们优化的新…

大数据技术5:OLAP引擎对比分析

前言:数据仓库建设,初级的理解就是建表,将业务数据、日志数据、消息队列数据等,通过各种调度任务写入到表里供OLAP引擎使用。但要想建好数仓也是一个复杂、庞大的工程,比如要考虑:数据清洗、数据建模&#…

联邦多任务蒸馏助力多接入边缘计算下的个性化服务 | TPDS 2023

联邦多任务蒸馏助力多接入边缘计算下的个性化服务 | TPDS 2023 随着移动智能设备的普及和人工智能技术的发展,越来越多的分布式数据在终端被产生与收集,并以多接入边缘计算(MEC)的形式进行处理和分析。但是由于用户的行为模式与服务需求的多样,不同设备上的数据分布…

【2023传智杯-新增场次】第六届传智杯程序设计挑战赛AB组-DEF题复盘解题分析详解【JavaPythonC++解题笔记】

本文仅为【2023传智杯-第二场】第六届传智杯程序设计挑战赛-题目解题分析详解的解题个人笔记,个人解题分析记录。 本文包含:第六届传智杯程序设计挑战赛题目、解题思路分析、解题代码、解题代码详解 文章目录 一.前言二.赛题题目D题题目-E题题目-F题题目-二.赛题题解D题题解-…

thinkphp6入门(12)-- 一对一关联模型

定义一对一关联,例如,一个用户都有一个个人资料。 一、两表 1.用户表:user 2.工作经验表:work_experience user表的id关联work_experience表的user_id。 注意看,user_id1的有2条工作经验 二、数据模型 主表模型:…

求导公式,求导的四则运算,复合函数求导

求导公式 求导的四则运算 复合函数求导

目标检测、目标跟踪、重识别

文章目录 环境前言项目复现特征提取工程下载参考资料 环境 ubuntu 18.04 64位yolov5deepsortfastreid 前言 基于YOLOv5和DeepSort的目标跟踪 介绍过针对行人的检测与跟踪。本文介绍另一个项目,结合 FastReid 来实现行人的检测、跟踪和重识别。作者给出的2个主…

swing快速入门(一)

注释很详细,直接上代码 涉及内容 1. 默认布局方式BorderLayout 2. 设置窗口位置和大小 3. 设置窗口可见性 4. panel对象(面板容器) 5. 文本和按钮组件的创建 6. 组件和容器的嵌套 import java.awt.*;public class Main{public static …

MN316 OpenCPU丨HTTP使用介绍

HTTP(Hyper Text Transfer Protocol)即超文本传输协议,是一个简单的请求-响应协议,通常运行在TCP之上,它指定了客户端可能发送给服务器消息类型以及得到什么类型响应。HTTPS(Hyper Text Transfer Protoc…

二维码智慧门牌管理系统升级:社区关怀

文章目录 前言一、系统的工作原理二、系统功能与关怀服务三、社区关怀的意义 前言 随着科技的发展,生活日益智能化,门牌系统也随之发展。近日,一种新型的二维码智慧门牌管理系统正在崛起,以创新的方式将社区关怀融入到每一个家庭…

STM32F407-14.3.9-02输出比较模式

输出比较模式 输出比较模式生成波形时 当采用上升沿或下降沿计数时,更改ARR的值可改变周期; 更改CCRx的值会影响到生成波形的相位。波形的占空比永远50% 当采用中心对齐模式时, 更改ARR的值可以改变周期,更改CCRx的值可以改…

动态规划(dp)初步学习案例讲解

问题(来源:leetcode300): 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如&a…

HarmonyOS--ArkTS(1)--基本语法(1)

目录 基本语法概述 声明式UI描述 自定义组件 创建自定义组件 自定义组件的结构--struct ,Component,build()函数 生命周期 基本语法概述 装饰器: 用于装饰类、结构、方法以及变量,并赋予其特殊的含义。如上述示例中Entry、C…

TypeScript基本语法

想在自己电脑上快速演示下方代码?点击ts官方演练场:https://www.typescriptlang.org/play 变量声明:TypeScript 在 Javascript的基础上加入了静态类型检查功能,因此每一个变量都有固定的数据类型。 //string: 字符串,…

GPT-4 变懒了?官方回复

你是否注意到,最近使用 ChatGPT 的时候,当你向它提出一些问题,却得到的回应似乎变得简短而敷衍了?对于这一现象,ChatGPT 官方给出了回应。 译文:我们听到了你们所有关于 GPT4 变得更懒的反馈!我…

智能优化算法应用:基于蜉蝣算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于蜉蝣算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于蜉蝣算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.蜉蝣算法4.实验参数设定5.算法结果6.参考文献7.MA…