当前位置: 首页 > news >正文

MySQL 程序设计课程复习大纲

作为一门基础的 MySQL 程序设计课程,期末复习的重点应放在常见的数据库操作、基本查询、数据建模、关系型数据库的规范化设计等方面。以下是针对基础课程的 MySQL 期末复习知识点。

1. MySQL 基础概念与数据库操作

  • 数据库基础

    • 数据库与表的概念
    • 数据库管理系统(DBMS)的作用与功能
    • MySQL 与其他数据库的区别
    • MySQL 的安装与配置
  • 基本的数据库操作

    • 创建数据库:CREATE DATABASE
    • 删除数据库:DROP DATABASE
    • 查看当前数据库:SHOW DATABASES
    • 选择数据库:USE
  • 表的创建与管理

    • 创建表:CREATE TABLE
    • 删除表:DROP TABLE
    • 修改表结构:ALTER TABLE
    • 查看表结构:DESCRIBESHOW COLUMNS
    • 表的约束:PRIMARY KEYNOT NULLUNIQUEFOREIGN KEYCHECK(根据 MySQL 版本)

2. 数据类型与表设计

  • 常用数据类型

    • 整数类型:INT, TINYINT, BIGINT
    • 浮点类型:FLOAT, DOUBLE, DECIMAL
    • 字符类型:CHAR, VARCHAR, TEXT
    • 日期和时间类型:DATE, DATETIME, TIMESTAMP, TIME
    • 布尔类型:BOOLEAN(实际上是 TINYINT(1)
    • 枚举类型:ENUMSET
  • 字段约束

    • 主键(Primary Key):唯一且不能为空,自动索引
    • 外键(Foreign Key):与其他表的字段建立关联,维护参照完整性
    • 唯一约束(Unique):保证字段值唯一
    • 非空约束(NOT NULL):字段不能为空
    • 默认值(DEFAULT):指定默认值
  • 表的设计规范

    • 数据库范式:第一范式 (1NF)第二范式 (2NF)第三范式 (3NF) 的概念与应用
    • 如何避免冗余数据,设计合适的主外键关系
    • 规范化与反规范化的选择

3. SQL 查询语言

  • 基本查询

    • SELECT 查询:选择指定的列
    • FROM 子句:指定查询的表
    • WHERE 条件:筛选满足条件的记录
    • ORDER BY 排序:根据一个或多个字段排序,ASC(升序)、DESC(降序)
    • LIMIT 限制返回的记录数
  • 常见的查询操作

    • 使用 AND, OR, NOT 来组合多个条件
    • 模糊查询:LIKE 与通配符(%, _
    • IN:指定多个可能的值
    • BETWEEN:范围查询
    • NULL 判断:IS NULL, IS NOT NULL
  • 聚合函数

    • 常见聚合函数:COUNT(), SUM(), AVG(), MIN(), MAX()
    • GROUP BY:分组查询
    • HAVING:对分组结果进行筛选(与 WHERE 的区别)

4. 多表查询

  • 连接查询

    • 内连接(INNER JOIN):返回两个表中匹配的记录
    • 左连接(LEFT JOIN):返回左表所有记录以及右表中匹配的记录
    • 右连接(RIGHT JOIN):返回右表所有记录以及左表中匹配的记录
    • 全连接(FULL JOIN):返回左右表所有记录(MySQL 不直接支持,需要使用 UNION
    • 自连接:同一个表进行连接查询
  • 子查询

    • 单行子查询:返回单行单列的结果
    • 多行子查询:使用 INANYALL 等关键字
    • 关联子查询:在子查询中使用外部查询的字段

5. 数据操作语言(DML)

  • 数据插入(INSERT)

    • 插入单行数据:INSERT INTO table (columns) VALUES (values)
    • 插入多行数据:INSERT INTO table (columns) VALUES (value1), (value2)
    • 插入时使用默认值:INSERT INTO table DEFAULT VALUES
  • 数据更新(UPDATE)

    • 更新指定字段的值:UPDATE table SET column = value WHERE condition
    • 多行更新:一次更新多条记录
  • 数据删除(DELETE)

    • 删除指定记录:DELETE FROM table WHERE condition
    • 删除所有记录DELETE FROM table(不删除表结构)

6. 数据控制语言(DCL)

  • 权限控制

    • 用户管理:CREATE USER, DROP USER, GRANT, REVOKE
    • 用户权限分配:授予、撤销权限,例如:GRANT SELECT, INSERT ON database TO 'user'@'host'
  • 事务控制

    • 事务的概念:ACID(原子性、一致性、隔离性、持久性)
    • 事务命令:START TRANSACTION, COMMIT, ROLLBACK
    • 锁机制:行级锁、表级锁

7. 索引与优化

  • 索引的基本概念

    • 索引的作用:提高查询效率
    • 常见索引类型:单列索引、多列索引、唯一索引、全文索引
    • 创建索引CREATE INDEX
    • 删除索引DROP INDEX
  • 查询优化

    • 使用 EXPLAIN 查看查询执行计划
    • 常见的查询优化技巧:避免全表扫描、减少子查询使用、合理设计索引

8. 视图与存储过程

  • 视图(View)

    • 视图的概念与创建:CREATE VIEW
    • 查询视图与删除视图:SELECT FROM viewDROP VIEW
  • 存储过程(Stored Procedures)

    • 存储过程的创建与调用:CREATE PROCEDURECALL
    • 参数:输入参数、输出参数、IN/OUT 参数
    • 存储过程的使用场景与优化

9. 常见的错误与调试

  • 常见的 SQL 错误
    • 语法错误、数据类型错误、主外键约束错误
    • 查询返回空结果或无匹配数据时的调试技巧
  • 调试技巧
    • 使用 SHOW ERRORS 查看错误信息
    • 分析查询的执行计划

复习建议:

  • 重点掌握:SELECT 查询、JOIN 操作、数据的增删改查、表结构设计、索引与优化。
  • 多做练习:通过大量的 SQL 练习来巩固知识点,尤其是多表查询、嵌套查询和子查询。

相关文章:

MySQL 程序设计课程复习大纲

作为一门基础的 MySQL 程序设计课程,期末复习的重点应放在常见的数据库操作、基本查询、数据建模、关系型数据库的规范化设计等方面。以下是针对基础课程的 MySQL 期末复习知识点。 1. MySQL 基础概念与数据库操作 数据库基础 数据库与表的概念数据库管理系统&…...

C++ : STL容器(适配器)之stack、queue剖析

STL容器适配器之stack、queue剖析 一、stack、queue的接口(一)stack 接口说明(二)queue 接口说明 二、stack、queue的模拟实现(一)stack、queue是容器适配器stack、queue底层默认容器--deque1、deque概念及…...

nuxt3安装pinia报错500[vite-node] [ERR_LOAD_URL]问题解决

按照pinia官网步骤安装运送服务会报一个500[vite-node] [ERR_LOAD_URL]问题,查阅各个网站资料没有找到有用信息. 最后解决:在package.json中把pinia的版本给降回0.5.5版本之后就正常了 "dependencies": {"element-plus/icons-vue": "^2.3.1",&q…...

青少年编程能力等级测评CPA试卷(2)Python编程(一级)

青少年编程能力等级测评CPA试卷(2) Python编程(一级) (考试时间90分钟,满分100分) 一、单项选择题(共20题,每题3.5分,共70分) 下列语句的输出结果是( &am…...

wordpress判断page页与非page页

在WordPress中&#xff0c;你可以使用is_page()函数来判断当前页面是否为page类型。以下是如何使用这个函数的示例&#xff1a; <?php if (is_page()) {// 当前页面是page类型echo 这是一个Page页面; } else {// 当前页面不是page类型echo 这不是一个Page页面; } ?> …...

JavaScript 库-qs的使用

meta.query qs.parse(query)语句解析&#xff1a;qs.parse(query) qs 是一个常用的 JavaScript 库&#xff08;全称为 query-string 或 qs&#xff09;&#xff0c;它用于处理 URL 查询字符串。qs.parse(query) 会将查询字符串解析成一个对象。举个例子&#xff1a; 假设有一…...

Leetcode 两数之和 Ⅱ - 输入有序数组

这段代码实现了在一个非递减排序的数组中找到两个数&#xff0c;使它们的和等于目标值的算法。算法使用了双指针技术&#xff0c;具体思想如下&#xff1a; 算法思想&#xff1a; 初始化指针&#xff1a;定义两个指针 left 和 right&#xff0c;分别指向数组的起始位置和末尾位…...

多处理器一致协议(MSI)协议详细介绍

多处理器一致协议 MSI 协议详细介绍 #mermaid-svg-2lc6AxM2mRiND4C0 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-2lc6AxM2mRiND4C0 .error-icon{fill:#552222;}#mermaid-svg-2lc6AxM2mRiND4C0 .error-text{fill:…...

SSH实验5密钥登录Linuxroot用户(免密登录)

当用户尝试通过SSH连接到远程服务器时&#xff0c;客户端会生成一对密钥&#xff1a;公钥和私钥。公钥被发送到远程服务器&#xff0c;并存储在服务器的~/.ssh/authorized_keys文件中。而私钥则由客户端保管&#xff0c;不会传输给服务器。 在连接过程中&#xff0c;客户端使用…...

2024 网鼎杯 - 青龙组 Web WP

2024 网鼎杯 - 青龙组 WEB - 02 打开容器一个登录界面&#xff0c;随便输入账号密码可以进到漏洞界面 这里有一个发送给boss的功能&#xff0c;一眼xss 有三个接口&#xff1a;/flag 、/update 、/submit /flag &#xff1a;要求boss才能访问&#xff0c;/update &#xf…...

ORACLE 闪回技术简介

闪回技术是若干技术的集合 包含对数据库整体的闪回 对表的闪回 对事务的闪回 经典面试题面试题&#xff1a;简述Oracle数据库闪回技术&#xff1f; 1.闪回Oracle数据库 2.闪回表 3.闪回事务 数据库闪回 要想实现数据库闪回 1.必须配置数据库的恢复区 SQL> show parameter …...

【笔记】LLC电路工作频点选择 2-2 开关管与滤波压力

LLC谐振变换器稳态工作波形分析 - 知乎&#xff0c;上面这篇文的结论相较MPS那篇文章的结论更严格。我们分析一下它的频点选择为什么会更窄&#xff1a; 1. LLC电路模型 电流滞后的特性就是电路呈感性注意这里也是开关管ZVS开通。 2.工作循环的波形 iLm的波形&#xff0c;最终…...

【CUDA】认识CUDA

目录 一、CUDA编程 二、第一个CUDA程序 三、CUDA关键字 四、device管理 4.1 初始化 4.2 Runtime API查询GPU信息 4.3 决定最佳GPU CUDA C 编程指南CUDA C在线文档&#xff1a;CUDA C 编程指南 CUDA是并行计算的平台和类C编程模型&#xff0c;能很容易的实现并行算法。只…...

Linux(CentOS)yum update -y 事故

CentOS版本&#xff1a;CentOS 7 事情经过&#xff1a; 1、安装好CentOS 7&#xff0c;系统自带JDK8&#xff0c;版本为&#xff1a;1.8.0_181 2、安装好JDK17&#xff0c;版本为&#xff1a;17.0.13 3、为了安装MySQL执行了 yum update -y&#xff08;这个时候不知道该命令的…...

AI绘画赚钱秘籍!掌握ai绘画赚钱技巧,开启副业新篇章,ai绘画赚钱实战指南!

AI绘画赚钱&#xff1a;方法与策略 一、引言 ​ 随着人工智能技术的日益发展&#xff0c;AI绘画作为新兴领域&#xff0c;正逐渐成为赚钱的新途径。本文将从多个角度探讨AI绘画赚钱的完整策略&#xff0c;帮助读者深入了解并把握这一领域的商机。 二、AI绘画赚钱的主要方式…...

HCIP-HarmonyOS Application Developer V1.0 笔记(四)

平板/折叠屏设计 自适应动态布局&#xff1a;相对拉伸、相对缩放、延伸布局 响应式动态布局&#xff1a;挪移布局、重复布局、瀑布布局 Sketch 插件 设计系统&#xff1a;提供了 HarmonyOS 设计语言中定义的视觉参数和设计资源文件。 控件库&#xff1a;按类别组织控件&…...

【前端】Svelte:组件封装与使用

在 Svelte 中&#xff0c;组件化是开发的核心理念。将页面的不同部分封装成独立组件&#xff0c;不仅可以提升代码的复用性&#xff0c;还能让项目的结构更加清晰。在本文中&#xff0c;我们将介绍如何创建、封装、引入和使用 Svelte 组件&#xff0c;帮助你快速上手 Svelte 的…...

STM32标准库-待机模式

1.1 STM32待机模式简介 STM32单片机具有低功耗模式&#xff0c;包括睡眠、停止和待机三种。 运行状态下&#xff0c;HCLK为CPU提供时钟。HCLK由AHB预分频器分频后直接输出得到。 低功耗模式选择需考虑电源消耗、启动时间和唤醒源。 睡眠模式停CPU不停外设时钟&#xff1b; 停止…...

【论文笔记】The Power of Scale for Parameter-Efficient Prompt Tuning

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 基本信息 标题: The Power of Scale for P…...

几个docker可用的镜像源

几个docker可用的镜像源 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; sudo rm -rf /etc/docker/daemon.json sudo mkdir -p /etc/dockersudo tee /etc/docker/daemon.json <<-EOF {"registry-mirrors": ["https://d…...

DNF联机搭建避坑指南:从‘花枝登录器’授权到PVF加密的全流程解析

DNF私服联机搭建实战&#xff1a;从授权配置到加密通信的完整解决方案 当几个朋友想搭建一个私人DNF服务器享受联机乐趣时&#xff0c;最令人头疼的往往不是服务端的启动&#xff0c;而是如何让客户端顺利连接。本文将聚焦于那些让"单机变联机"的关键技术环节——登录…...

AIGC查重率多少合格?看完这篇就清楚了

相信不少用AI辅助写论文的同学都有过这种焦虑&#xff1a;深夜改完终稿&#xff0c;想起学校要求提交AIGC检测报告&#xff0c;翻遍论坛找不到明确的合格标准&#xff0c;手心出汗反复刷新搜索结果&#xff0c;就怕自己的AI生成占比超标过不了审。作为常年跟各类论文查重工具打…...

Cesium交互绘图避坑指南:从CallbackProperty到CustomDataSource的完整流程

Cesium交互绘图避坑指南&#xff1a;从CallbackProperty到CustomDataSource的完整流程 在三维地理信息可视化领域&#xff0c;Cesium凭借其强大的渲染能力和丰富的API接口&#xff0c;已成为开发者构建交互式地图应用的首选工具。然而&#xff0c;当涉及动态绘图功能时&#xf…...

PyTorch训练二分类模型时,你的损失函数为什么突然变成NaN了?排查BCELoss的5个坑

PyTorch训练二分类模型时&#xff0c;你的损失函数为什么突然变成NaN了&#xff1f;排查BCELoss的5个坑 深夜的调试台前&#xff0c;咖啡杯早已见底&#xff0c;屏幕上那个刺眼的"nan"却依然顽固地停留在损失值的位置。这不是第一次&#xff0c;也不会是最后一次——…...

当柔性车间遇上强化学习:从传统规则到DRL的调度进化史

柔性车间调度的智能革命&#xff1a;深度强化学习如何重塑制造业决策 在当今快节奏、定制化需求激增的制造业环境中&#xff0c;传统的生产调度方法正面临前所未有的挑战。想象一下&#xff0c;一个典型的电子设备制造车间&#xff1a;数百种不同规格的订单不断涌入&#xff0c…...

Ubuntu 20.04 LTS下Miniconda3安装与配置全攻略(含常见错误解决)

Ubuntu 20.04 LTS下Miniconda3安装与配置全攻略&#xff08;含常见错误解决&#xff09; 如果你正在Ubuntu 20.04 LTS上搭建Python开发或数据科学环境&#xff0c;Miniconda3绝对是一个值得考虑的选择。作为Anaconda的精简版&#xff0c;它保留了核心的conda包管理功能&#x…...

从零开始:手把手教你用Git和GitHub管理个人项目(含常见问题解答)

从零开始&#xff1a;手把手教你用Git和GitHub管理个人项目&#xff08;含常见问题解答&#xff09; 第一次接触Git时&#xff0c;我盯着命令行里那些神秘的add、commit、push指令发呆了半小时——它们看起来像某种编程黑话。直到把个人博客项目搞砸三次后&#xff0c;我才真正…...

nli-distilroberta-base效果展示:Entailment/Contradiction/Neutral三类判别置信度热力图

nli-distilroberta-base效果展示&#xff1a;Entailment/Contradiction/Neutral三类判别置信度热力图 1. 项目概述 nli-distilroberta-base是基于DistilRoBERTa模型的自然语言推理(NLI)Web服务&#xff0c;专门用于分析两个句子之间的逻辑关系。这个轻量级模型能够快速准确地…...

你的电动车续航打折了?可能是AMT换挡逻辑没调好!聊聊经济性换挡那些事儿

你的电动车续航打折了&#xff1f;可能是AMT换挡逻辑没调好&#xff01;聊聊经济性换挡那些事儿 最近在车主群里经常看到这样的抱怨&#xff1a;"明明官方标称续航500公里&#xff0c;怎么我开起来连400都跑不到&#xff1f;"作为一位开了三年电动车的"老司机&q…...

Janus-Pro-7B模型部署精讲:VMware虚拟机中的隔离环境搭建

Janus-Pro-7B模型部署精讲&#xff1a;VMware虚拟机中的隔离环境搭建 想在自己的电脑上测试Janus-Pro-7B这类大模型&#xff0c;但又担心搞乱本地环境&#xff0c;或者影响其他工作&#xff1f;用虚拟机搭建一个隔离的测试环境&#xff0c;是个非常稳妥的选择。它就像在你的电…...