【SQL】期末复习SQL语法详细总结

news2025/1/5 10:25:02

1. 创建数据库

CREATE DATABASE 数据库名;
  • 用于创建一个新的数据库。

  • 可以使用选项设置字符集、排序规则等:

    CREATE DATABASE 数据库名 CHARACTER SET utf8 COLLATE utf8_general_ci;
    

2. 创建表

CREATE TABLE 表名 (
    列名 数据类型 [列级完整性约束],
    [列名 数据类型 [列级完整性约束], ...]
    [表级完整性约束]
);
  • 数据类型:如 INT, VARCHAR(255), DATE 等。
  • 列级完整性约束:如 NOT NULL, DEFAULT, UNIQUE 等。
  • 表级完整性约束:如 PRIMARY KEY, FOREIGN KEY, CHECK 等。

例如:

CREATE TABLE employees (
    id INT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    age INT CHECK (age > 0)
);

3. 修改表结构

ALTER TABLE 表名
    ADD COLUMN 列名 数据类型 [列级完整性约束],
    ADD CONSTRAINT 约束名 约束类型,
    DROP COLUMN 列名,
    DROP CONSTRAINT 约束名,
    MODIFY COLUMN 列名 数据类型;
  • ADD COLUMN:添加新的列。
  • ADD CONSTRAINT:添加约束(如主键、外键等)。
  • DROP COLUMN:删除某一列。
  • DROP CONSTRAINT:删除约束。
  • MODIFY COLUMN:修改列的数据类型或约束。

例如:

ALTER TABLE employees
    ADD COLUMN email VARCHAR(100),
    MODIFY COLUMN age INT NOT NULL;

4. 查询语句

SELECT [ALL | DISTINCT] 目标列表达式 [AS 别名], ...
FROM 表名 [AS 别名], ...
[WHERE 条件表达式]
[GROUP BY 列名1, ...]
[HAVING 条件表达式]
[ORDER BY 列名2 [ASC | DESC]];
  • ALL:默认,返回所有记录。
  • DISTINCT:去重,返回不同的记录。
  • WHERE:过滤条件。
  • GROUP BY:分组,通常与聚合函数(如 COUNT, SUM)一起使用。
  • HAVING:对分组结果进行过滤。
  • ORDER BY:排序,ASC 表示升序,DESC 表示降序。

例如:

SELECT name, age
FROM employees
WHERE age > 30
ORDER BY name DESC;

5. 修改表数据

UPDATE 表名
SET 列名 = 表达式 [, 列名 = 表达式, ...]
WHERE 条件;
  • 更新指定列的值,使用 WHERE 子句限制更新范围。

例如:

UPDATE employees
SET age = age + 1
WHERE name = 'John';

6. 插入表数据(两种形式)

1) 使用常量值插入

INSERT INTO 表名 (属性列1, 属性列2, ...)
VALUES (常量1, 常量2, ...);

2) 使用子查询插入

INSERT INTO 表名 (属性列1, 属性列2, ...)
SELECT1,2, ...
FROM 另一个表;

例如:

INSERT INTO employees (id, name, age)
VALUES (1, 'Alice', 25);

INSERT INTO employees (id, name, age)
SELECT id, name, age
FROM temp_employees;

7. 删除表

DROP TABLE 表名;
  • 删除表及其中的所有数据、结构及约束。

8. 删除表数据

DELETE FROM 表名
[WHERE 条件];
  • 删除表中的数据,不删除表结构。
  • 如果没有 WHERE 条件,则删除表中所有数据。

例如:

DELETE FROM employees
WHERE age < 20;

9. 创建视图

CREATE VIEW 视图名 [(列名1, 列名2, ...)] AS 子查询 [WITH CHECK OPTION];
  • WITH CHECK OPTION:限制通过视图进行的数据更新操作,确保更新后符合视图的条件。

例如:

CREATE VIEW senior_employees AS
SELECT name, age
FROM employees
WHERE age >= 40;

10. 创建索引

CREATE [UNIQUE] [FULLTEXT] [SPATIAL] INDEX 索引名 ON 表名 (列名 [ASC|DESC], ...);
  • UNIQUE:创建唯一索引,确保索引列的值唯一。
  • FULLTEXT:创建全文索引,适用于文本字段。
  • SPATIAL:空间索引,用于地理信息系统(GIS)数据。
  • ASC | DESC:排序顺序,默认为升序 ASC

例如:

CREATE INDEX idx_name ON employees (name);
CREATE UNIQUE INDEX idx_email ON employees (email);

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

linux下安装tun模块详细教程

原本是要看tcp/ip协议栈&#xff0c;找到了https://github.com/chobits/tapip这个。然后需要支持tun&#xff0c;完了开始安装。 TUN/TAP是一个虚拟网络设备&#xff0c;用于实现用户态程序和内核网络协议栈之间的数据交互。 1、安装环境 我的系统是ubuntu16.04 VMWare虚拟机&a…

Ajax数据爬取

有时我们用requests 抓取页面得到的结果&#xff0c;可能和在浏览器中看到的不一样:在浏览器中可以看到正常显示的页面数据&#xff0c;而使用requests 得到的结果中并没有这些数据。这是因为 requests 获取的都是原始 HTML 文档&#xff0c;而浏览器中的页面是JavaScript 处理…

Docker 安装与配置 Nginx

摘要 1、本文全面介绍了如何在 Docker 环境中安装和配置 Nginx 容器。 2、文中详细解释了如何设置 HTTPS 安全连接及配置 Nginx 以实现前后端分离的代理服务。 2、同时&#xff0c;探讨了通过 IP 和域名两种方式访问 Nginx 服务的具体配置方法 3、此外&#xff0c;文章还涵…

SpringCloud微服务架构

文章目录 认识微服务&#xff1a;SpringCloud 服务拆分及远程调用实现夸远程服务调用使用RestTemplateEureka注册中心 搭建EruekaServer注册服务服务发现 Ribbon负载均衡 修改负载均衡规则解饿加载 Nacos注册中心&#xff08;nacos一部分功能&#xff09; 服务注册到nacosnacos…

WireShark4.4.2浏览器网络调试指南:TCP传输包分析(七)

概述 在使用Wireshark进行网络分析时&#xff0c;理解每一个数据包的组成部分对于网络分析非常重要。特别是在TCP协议中的“三次握手”过程中&#xff0c;每个数据包会包含多个层次的信息&#xff0c;从帧信息到TCP协议的详细内容。下面是对TCP握手过程中第一个SYN数据包的详细…

kafka使用常见问题

连接不上kafka,报下边的错 org.apache.kafka.common.KafkaException: Producer is closed forcefully.at org.apache.kafka.clients.producer.internals.RecordAccumulator.abortBatches(RecordAccumulator.java:760) [kafka-clients-3.0.2.jar:na]at org.apache.kafka.client…

用uniapp写一个播放视频首页页面代码

效果如下图所示 首页有导航栏&#xff0c;搜索框&#xff0c;和视频列表&#xff0c; 导航栏如下图 搜索框如下图 视频列表如下图 文件目录 视频首页页面代码如下 <template> <view class"video-home"> <!-- 搜索栏 --> <view class…

深入浅出:从入门到精通大模型Prompt、SFT、RAG、Infer、Deploy、Agent

阅读原文 渐入佳境 我们都知道&#xff0c;通过编写一个提示词&#xff08;prompt&#xff09;&#xff0c;我们可以引导大模型生成回答&#xff0c;从而开启愉快的人工智能对话&#xff0c;比如让模型介绍一下卡皮巴拉。上边简图描述了这个过程&#xff0c;我们拆成两部分 pr…

Unity-Mirror网络框架-从入门到精通之Basic示例

文章目录 前言Basic示例场景元素预制体元素代码逻辑BasicNetManagerPlayer逻辑SyncVars属性Server逻辑Client逻辑 PlayerUI逻辑 最后 前言 在现代游戏开发中&#xff0c;网络功能日益成为提升游戏体验的关键组成部分。Mirror是一个用于Unity的开源网络框架&#xff0c;专为多人…

【新方法】通过清华镜像源加速 PyTorch GPU 2.5安装及 CUDA 版本选择指南

下面详细介绍所提到的两条命令&#xff0c;它们的作用及如何在你的 Python 环境中加速 PyTorch 等库的安装。 1. 设置清华镜像源 pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple这条命令的作用是将 pip &#xff08;Python 的包管理工具&#xf…

自动化测试-Pytest测试

目录 pytest简介 基本测试实例 编写测试文件 执行测试 pytest运行时参数 mark标记 Fixture pytest插件 Allure测试报告 测试步骤 pytest简介 Pytest‌是一个非常流行的Python测试框架&#xff0c;它支持简单的单元测试和复杂的功能测试&#xff0c;具有易于上手、功…

Java-33 深入浅出 Spring - FactoryBean 和 BeanFactory BeanPostProcessor

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 大数据篇正在更新&#xff01;https://blog.csdn.net/w776341482/category_12713819.html 目前已经更新到了&#xff1a; MyBatis&#xff…

MySQL 服务器简介

通常所说的 MySQL 服务器指的是mysqld程序&#xff0c;当运⾏mysqld后对外提供MySQL 服务&#xff0c;这个专题的内容涵盖了以下关于MySQL 服务器以及相关配置的内容&#xff0c;包括&#xff1a; 服务器⽀持的启动选项。可以在命令⾏和配置⽂件中指定这些选项。 服务器系统变…

分布式版本管理工具——Git关联远程仓库(github+gitee)

Git远程仓库&#xff08;Github&#xff09;的基本使用 一、前言二、Git远程仓库介绍三、演示1. 关联github远程仓库2. 关联gitee&#xff08;码云&#xff09;远程仓库3. 重命名远程仓库名4. 移除远程仓库 四、结束语 一、前言 古之立大事者&#xff0c;不惟有超世之才&#x…

ZLib库使用详细教程 以及标准ZLib函数和QT自带压缩函数比较

1. 下载Zlib 官网下载地址如下&#xff1a;http://www.zlib.net/ 2. 利用cmake编译zlib 有两种方法可以打开cmake-gui winR输入cmd打开命令行&#xff0c;在命令行中输入cmake-gui可以直接打开应用界面找到你一开始安装cmake的文件夹&#xff0c;在bin子文件夹中双击cmake-…

加载Tokenizer和基础模型的解析及文件介绍:from_pretrained到底加载了什么?

加载Tokenizer和基础模型的解析及文件介绍 在使用Hugging Face的transformers库加载Tokenizer和基础模型时&#xff0c;涉及到许多文件的调用和解析。这篇博客将详细介绍这些文件的功能和它们在加载过程中的作用&#xff0c;同时结合代码片段进行解析。 下图是我本地下载好模…

SpringAI从入门到熟练

学习SpringAI的记录情况 文章目录 前言 因公司需要故而学习SpringAI文档&#xff0c;故将自己所见所想写成文章&#xff0c;供大佬们参考 主要是为什么这么写呢&#xff0c;为何不抽出来呢&#xff0c;还是希望可以用的时候更加方便一点&#xff0c;如果大家有需求可以自行去…

嵌入式系统中C++的基本使用方法

大家好,今天主要给大家分享一下,最近操作C++代码的控制方法。 什么是构造函数?构造函数在对象实例化时被系统自动调用,仅且调用一次。 什么是析构函数?与构造函数相反, 在对象结束其生命周期时系统自动执行析构函数。 第一个:析构函数与构造函数区别 实例代码: #inclu…

【Qt】多元素控件:QListWidget、QTableWidget、QTreeWidget

目录 QListWidget 核心属性&#xff1a; 核心方法&#xff1a; 核心信号&#xff1a; 例子&#xff1a; QListWidgetItem QTableWidget 核心方法&#xff1a; 核心信号 QTableWidgetItem 例子&#xff1a; QTreeWidget 核心方法&#xff1a; 核心信号&#xff1a…

HTML5 标签输入框(Tag Input)详解

HTML5 标签输入框&#xff08;Tag Input&#xff09;详解 标签输入框&#xff08;Tag Input&#xff09;是一种用户界面元素&#xff0c;允许用户输入多个标签或关键词&#xff0c;通常用于表单、搜索框或内容分类等场景。以下是实现标签输入框的详细讲解。 1. 任务概述 标…