数据库语言、SQL语言、数据库系统提供的两种语言

embedded/2024/11/13 15:02:13/

1.数据库语言

数据库语言有很多种,其中一种是SQL语言。

2. SQL语言

【几乎所有的关系数据库系统都使用SQL语言。】

SQL语言中包含很多不同的部分,有:
(1)DDL语言(Data definition language),数据定义语言:
用于描述数据库中要存储的现实世界实体的语言。

(2)DML语言(Data Manipulation Language),数据操纵语言:
使用户能够查询数据库以及操作已有数据库中的数据的计算机语言。

(3)DCL语言(Data control language),数据库控制语言:
用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL.
关键字:GRANT, REVOKE

(4)TCL语言(Transaction Control Language),事务控制语言:
对事务进行控制的语句,包括commit,rollback等语言。

3.数据库系统提供的两种语言

(1)数据定义语言DDL:用于描述数据库中要存储的现实世界实体的语言。
可说明(三个层次的)数据库模式,或定义数据的其他特征。
DDL的输出放在数据字典(data dictionary)中,数据字典包含元数据(metadata),元数据是关于数据的数据。

DDL包含很多种。
其中,典型地如 数据存储和定义(data storage and definition)语言:
定义了数据库模式的实现细节,而这些细节对用户来说通常是不可见的。
数据存储和定义语言必须由计算机软件进行编译,转换为便于计算机存储、查询和操纵的格式,完成这个转换工作的程序称为模式编译器。

sql">SQL提供了丰富的DDL语言。SQL类型的数据定义语言DDL称为 SQL数据定义语言DDL ,可以用来定义(逻辑层次的逻辑模式中)具有数据类型和完整性约束的表。
关键字: CREATE, ALTER, DROP, RENAME, TRUNCATE 例如:用 SQL数据定义语言DDL 中 的数据存储和定义语言 ,定义一个department表:create table department(dep5ame char (20), building budgetchar (15), numeric (12,2));

(2)数据操纵语言DML:使用户能够查询数据库以及操作已有数据库中的数据的计算机语言。

DML可分成交互型DML和嵌入型DML两类。
交互型DML:这类DML自成系统,可在终端上直接对数据库进行操作。
嵌入型DML:这类DML是嵌入在主语言中使用。此时主语言是经过扩充能处理DML语句的语言。

依据语言的级别,DML又可分成过程性DML和非过程性DML两种。
过程性DML:用户编程时,不仅需要指出“做什么”(需要什么样的数据),还需要指出“怎么做”(怎么获得数据)。层状、网状的DML属于过程性语言。
非过程性DML:用户编程时,只需要指出“做什么”,不需要指出“怎么做”。关系型DML属于非过程性语言。

查询(query)是要求对信息进行检索的语句。
DML中涉及信息检索的部分称作查询语言(query language)。
由此可见,查询语言只属于DML语言中的一种。

sql">SQL类型的数据操纵语言DML称为 SQL数据操纵语言DML.
关键字:INSERT, UPDATE, DELETESQL数据操纵语言DML中的查询语言(简称SQL查询语言,Data Query Language,简写DQL语言),指SELECT 数据查询语言,是非过程化的。
该SQL查询以几个表作为输入(也可能只有一个表),但总是仅返回一个表。
数据查询语言DQL基本结构是由SELECT子句,FROM子句,WHERE子句组成的查询块。一般结构为:
SELECT <字段名表>FROM <表或视图名>WHERE <查询条件>

【参考文章:SQL中的四种语言DML DDL DCL TCL —— 游语 】


http://www.ppmy.cn/embedded/114497.html

相关文章

flink doris批量sink

idea maven 依赖 <dependency> <groupId>org.apache.doris</groupId> <artifactId>flink-doris-connector-1.11_2.12</artifactId> <version>1.0.3</version> </dependency> val properties Properties() properties.setPro…

在SpringBoot项目中利用Redission实现布隆过滤器(布隆过滤器的应用场景、布隆过滤器误判的情况、与位图相关的操作)

文章目录 1. 布隆过滤器的应用场景2. 在SpringBoot项目利用Redission实现布隆过滤器3. 布隆过滤器误判的情况4. 与位图相关的操作5. 可能遇到的问题&#xff08;Redission是如何记录布隆过滤器的配置参数的&#xff09;5.1 问题产生的原因5.2 解决方案5.2.1 方案一&#xff1a;…

代码随想录算法训练营Day5

242.有效的字母异位词 力扣题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 数组实现简单哈希表 class Solution {public boolean isAnagram(String s, String t) {if(s.length()!t.length()){return false;}int[] recordnew int[26];for(int i0;i<s.leng…

QTCreator 调试:unknown debugger type “No engine“

QTCreator 调试&#xff1a;unknown debugger type "No engine" - kaizenly - 博客园 (cnblogs.com) 一开始Debuggers---Auto-detected这里第一row第一个项是标红的&#xff0c;然后没改东西&#xff0c;点完应用Apply以后&#xff0c;就可以调试了...&#xff08;不…

http免费升级https教程

将HTTP免费升级至HTTPS的详细教程涉及获取SSL证书、配置服务器和测试HTTPS连接等关键步骤。 以下是具体介绍&#xff1a; 获取SSL证书&#xff1a;选择提供免费SSL证书的服务&#xff0c;如JoySSL。在证书提供商的网站上申请免费SSL证书注册时填写注册码230920&#xff0c;获取…

动手学深度学习(pytorch土堆)-06损失函数与反向传播、模型训练、GPU训练

模型保存与读取 完整模型训练套路 import torch import torchvision.datasets from torch import nn from torch.nn import Conv2d, MaxPool2d, Flatten, Linear from torch.utils.data import DataLoader from torch.utils.tensorboard import SummaryWriterfrom model impo…

Zabbix中文乱码问题解决

目录 1、问题 2、解决办法 1、问题 2、解决办法 WinR打开运行&#xff0c;输入fonts&#xff0c;回车进入Windows字体目录&#xff0c;找到微软雅黑-常规字体&#xff0c;复制出来将文件名修改为msyh.ttf&#xff0c;注意后缀ttf 将msyh.ttf上传到服务器zabbix字体目录中&am…

Day4:杨辉三角

题目&#xff1a;给定一个非负整数numRows,生成杨辉三角的前numRows行。在杨辉三角中&#xff0c;每个数就是左上方和右上方数的和。 import java.util.ArrayList; import java.util.List;public class Test {public static List<List<Integer>> generate(int numR…