百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

SQL知识大全(一):数据库的语言分类你都知道吗?

yuyutoo 2025-01-11 18:30 4 浏览 0 评论


点击上方蓝字关注我们


今天是数据库语言分类的第一讲,主要会介绍数据库的四类语言,以及其语法,课程大纲详见脑图。



数据库定义语言


数据库定义语言(DDL,Data Definition Language)是负责数据的模式定义与数据的物理存取构建,主要包括CREATE建表语句,ALTER 更新表结构语句,DROP 删除语句,DECLARE 创建游标。

CREATE建表语句

创建一张名为OrderItems的空表

CREATE TABLE OrderItems 
(
order_num     INTEGER              NOT NULL,
order_item    INTEGER              NOT NULL,
prod_id       CHAR(10)             NOT NULL,
quantity      INTEGER             NOT NULL   DEFAULT 1, 
item_price    DECIMAL(8,2)        NOT NULL
)


已有部分数据表,关联数据表,建中间表

CREATE VIEW ProductCustomers AS
SELECT cust_name, cust_contact, prod_id 


FROM Customers, Orders, OrderItems


WHERE Customers.cust_id = Orders.cust_id 


AND OrderItems.order_num = Orders.order_num;


ALTER 更新表结构

ALTER之前需要完成表的备份,因为ALTER的过程是不可逆的。

#增加一列
ALTER TABLE Vendors 
ADD vend_phone CHAR(20);
#删除一列
ALTER TABLE Vendors 
DROP COLUMN vend_phone;

DROP 删除表

DROP TABLE CustCopy;


数据操纵语言


数据操纵语言(DML,Data Manipulation Language):负责数据的操纵,包括查询及增、删、改等操作,SELECT(选择),DELETE(删除),UPDATE(更新),INSERT(插入)四类语法。


SELECT(选择)

SELECT说起来大家都不陌生,它是SQL中最常见的语法,主要用法是从数据表中选择你想要的那几列数据。

#选择表中的某列
SELECT
prod_name
FROM
Products;


#选择表中的多个列
SELECT prod_id, prod_name, prod_price
FROM Products;




#选择表中的所有列
SELECT
*
FROM
Products;


DELETE(删除)

DELETE删除行,甚至删除所有的行,但是并不删除表本身。如果要快速删除所有行,可以使用TRUNCATE TABLE语句,因为不记录数据变动。下面举几个例子。


1.从表中删除特定的行

下面这个例子是从Customers 这张表中,删除cust_id = '1000000006'的行。

DELETE FROM Customers 
WHERE cust_id = '1000000006'; 


2.从表中删除所有的行

下面例子删除所有的行,但是并不删除Customers 这张表。

DELETE FROM Customers


UPDATE(更新)

UPDATE(更新)由三部分组成,分别是要更新的表,列名和他们的新值,确定要更新那些行的过滤条件。

1.更新表中特定的列

#更新一列
UPDATE Customers
 SET cust_email = 'kim@thetoystore.com' WHERE cust_id = '1000000005'; 


#更新多列
UPDATE Customers
 SET cust_contact = 'Sam Roberts', 
 cust_email = 'sam@toyland.com' WHERE cust_id = '1000000006'; 


#删除某列
#删除某列可以将该列设为null
UPDATE Customers
 SET cust_email = NULL
 WHERE cust_id = '1000000005';


2.更新表中所有的行

该示例将Customers表中cust_email列全部更新为'kim@thetoystore.com' 。

UPDATE Customers
 SET cust_email = 'kim@thetoystore.com' 


INSERT(插入)

INSERT插入可以在数据表中插入完整的行,插入行的一部分,插入某些查询结果,下面我们将会给出几个例子进行说明。


1.插入完整的行

在Customers这张表中插入一行数据。

INSERT INTO Customers
VALUES('1000000006',
       'Toy Land',
       '123 Any Street',
       'New York',
       'NY',
       '11111',
       'USA',
       NULL,
       NULL);


2.插入行的一部分

在Customers表中插入部分行,cust_contact,cust_email字段没有插入数据。

INSERT INTO Customers(cust_id,
                      cust_name,
                      cust_address,
                      cust_city,
                      cust_state,
                      cust_zip,
                      cust_country,
                      cust_contact,
                      cust_email)
VALUES('1000000006',
       'Toy Land',
       '123 Any Street',
       'New York',
       'NY',
       '11111',
       'USA',
       NULL,
       NULL);


3.插入某些查询结果

从CustNew中SELECT出一些结果插入到Customers表中。

INSERT INTO Customers(cust_id,
                      cust_contact,
                      cust_email,
                      cust_name,
                      cust_address,
                      cust_city,
                      cust_state,
                      cust_zip,
                      cust_country)
SELECT cust_id,
       cust_contact,
       cust_email,
       cust_name,
       cust_address,
       cust_city,
       cust_state,
       cust_zip,
       cust_country


FROM CustNew;




数据控制语言


数据控制语言(DCL,Data Control Language):负责数据完整性、安全性的定义与检查以及并发控制、故障恢复等功能,主要语法有GRANT授权,REVOKE取消授权等。大部分情况下,这部分语法主要是提供给数据库工程师以及数仓开发使用的,分析师不太能用到这些语法,所以也不细讲了。


事务控制语


事务控制语言(TCL,Transaction Control Language)包括SAVEPOINT 设置保存点,它是事务处理中设置临时的占位符,可以对它发布回退;ROLLBACK 回滚,撤销指定的SQL语句;COMMIT提交,将未储存的SQL写入数据库表。


参考书籍:《SQL必知必会》


往期推荐


史上最全的SQL知识点汇总,错过这次等一年

数据岗知识体系及岗位介绍

【文末免费领资料】从生物医学转行到互联网数据分析师,我做对了什么?



分享数据知识,成就数据理想

相关推荐

当 Linux 根分区 (/) 已满时如何释放空间?

根分区(/)是Linux文件系统的核心,包含操作系统核心文件、配置文件、日志文件、缓存和用户数据等。当根分区满载时,系统可能出现无法写入新文件、应用程序崩溃甚至无法启动的情况。常见原因包括:...

玩转 Linux 之:磁盘分区、挂载知多少?

今天来聊聊linux下磁盘分区、挂载的问题,篇幅所限,不会聊的太底层,纯当科普!!1、Linux分区简介1.1主分区vs扩展分区硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两...

Linux 文件搜索神器 find 实战详解,建议收藏

在Linux系统使用中,作为一个管理员,我希望能查找系统中所有的大小超过200M文件,查看近7天系统中哪些文件被修改过,找出所有子目录中的可执行文件,这些任务需求...

Linux 操作系统磁盘操作(linux 磁盘命令)

一、文档介绍本文档描述Linux操作系统下多种场景下的磁盘操作情况。二、名词解释...

Win10新版19603推送:一键清理磁盘空间、首次集成Linux文件管理器

继上周四的Build19592后,微软今晨面向快速通道的Insider会员推送Windows10新预览版,操作系统版本号Build19603。除了一些常规修复,本次更新还带了不少新功能,一起来了...

Android 16允许Linux终端使用手机全部存储空间

IT之家4月20日消息,谷歌Pixel手机正朝着成为强大便携式计算设备的目标迈进。2025年3月的更新中,Linux终端应用的推出为这一转变奠定了重要基础。该应用允许兼容的安卓设备...

Linux 系统管理大容量磁盘(2TB+)操作指南

对于容量超过2TB的磁盘,传统MBR分区表的32位寻址机制存在限制(最大支持2.2TB)。需采用GPT(GUIDPartitionTable)分区方案,其支持64位寻址,理论上限为9.4ZB(9....

Linux 服务器上查看磁盘类型的方法

方法1:使用lsblk命令lsblk输出说明:TYPE列显示设备类型,如disk(物理磁盘)、part(分区)、rom(只读存储)等。...

ESXI7虚机上的Ubuntu Linux 22.04 LVM空间扩容操作记录

本人在实际的使用中经常遇到Vmware上安装的Linux虚机的LVM扩容情况,最终实现lv的扩容,大多数情况因为虚机都是有备用或者可停机的情况,一般情况下通过添加一块物理盘再加入vg,然后扩容lv来实...

5.4K Star很容易!Windows读取Linux磁盘格式工具

[开源日记],分享10k+Star的优质开源项目...

Linux 文件系统监控:用脚本自动化磁盘空间管理

在Linux系统中,文件系统监控是一项非常重要的任务,它可以帮助我们及时发现磁盘空间不足的问题,避免因磁盘满而导致的系统服务不可用。通过编写脚本自动化磁盘空间管理,我们可以更加高效地处理这一问题。下面...

Linux磁盘管理LVM实战(linux实验磁盘管理)

LVM(逻辑卷管理器,LogicalVolumeManager)是一种在Linux系统中用于灵活管理磁盘空间的技术,通过将物理磁盘抽象为逻辑卷,实现动态调整存储容量、跨磁盘扩展等功能。本章节...

Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!

Linux查看文件大小:ls和du为何结果不同?一文讲透原理!在Linux运维中,查看文件大小是日常高频操作。但你是否遇到过以下困惑?...

使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量

在Linux系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用...

Linux磁盘爆满紧急救援指南:5步清理释放50GB+小白也能轻松搞定

“服务器卡死?网站崩溃?当Linux系统弹出‘Nospaceleft’的红色警报,别慌!本文手把手教你从‘删库到跑路’进阶为‘磁盘清理大师’,5个关键步骤+30条救命命令,快速释放磁盘空间,拯救你...

取消回复欢迎 发表评论: