数据定义语言 - DDL

article/2025/9/12 21:50:51

写在前面:博主是一只经过实战开发历练后投身培训事业的“小山猪”,昵称取自动画片《狮子王》中的“彭彭”,总是以乐观、积极的心态对待周边的事物。本人的技术路线从Java全栈工程师一路奔向大数据开发、数据挖掘领域,如今终有小成,愿将昔日所获与大家交流一二,希望对学习路上的你有所助益。同时,博主也想通过此次尝试打造一个完善的技术图书馆,任何与文章技术点有关的异常、错误、注意事项均会在末尾列出,欢迎大家通过各种方式提供素材。

  • 对于文章中出现的任何错误请大家批评指出,一定及时修改。
  • 有任何想要讨论和学习的问题可联系我:zhuyc@vip.163.com。
  • 发布文章的风格因专栏而异,均自成体系,不足之处请大家指正。

数据定义语言 - DDL

本文关键字:数据库、数据定义语言、DDL、数据库对象

文章目录

  • 数据定义语言 - DDL
    • 一、DDL介绍
    • 二、常见数据库对象
      • 1. 数据库
      • 2. 数据表
      • 3. 视图
      • 4. 索引
      • 5. 序列
      • 6. 触发器
      • 7. 函数
      • 8. 存储过程
      • 9. 用户
    • 三、CREATE
      • 1. 创建数据表
      • 2. 创建视图
      • 3. 创建索引
    • 四、DROP
      • 1. 删除数据表
      • 2. 删除视图
      • 3. 删除索引

之前我们已经了解了SQL语言的分类,可以划分为:DDL(数据定义语言)、DML(数据操纵语言)、DQL(数据查询语言)、DCL(数据控制语言)、TPL(事务处理语言)、CCL(指针控制语言),本文将介绍DDL。

一、DDL介绍

DDL的全称是Data Definition Language,即:数据定义语言。在使用数据库操作数据时,一定要通过已经存在的结构,我们称之为数据库中的对象,如最常见的数据表。那么DDL的作用就是在结构上去管理和调整这些数据库对象,通常不会关心某个具体的数据,比如在删除某一个结构时,其中的数据也会被一同删除。

二、常见数据库对象

在学习DDL之前,有必要先来了解一下常见的数据库对象,有必要说明的是:某些数据库会弱化甚至于完全去掉某些数据库对象,使用其他的方式来代替相应的功能,不能够一概而论,所以本文只会演示最通用的数据库对象(数据表、视图、索引)的操作方式,其他的一些数据库对象请大家继续关注具体的数据库专栏,会逐步更新。

1. 数据库

说到数据库这个对象(database,有些工具会标记为schema),会有些称呼上的冲突,为了区分我们用DBMS来代表数据库软件本身。有些数据库会以数据库实例-表空间的方式来进行管理。其实思路上大同小异,都是为了提高管理效率,对数据表的所属进行适当的划分。
如果把整个DBMS想象成一个工作的工厂,那么数据库就相当于其中的一个个厂房,数据表就是厂房里的一个个货仓,数据就是其中的货物,也就是说数据库对象的主要作用就是作为数据表的所属的,有了这样的归属关系,不同的数据库之间就可以相对独立,同时也可以跨库操作

2. 数据表

数据表(table)是最常见的用于数据存储和操作的结构,由行和列组成,与我们使用的Excel很像,区别是更加规范,需要预先定义结构之后才能使用。其中每一行代表一条数据,每一列代表一个数据维度。

3. 视图

视图(view)也被称为虚表,相当于记录了一些设定的查询语句,是基于已经存在的表才能够创建的。视图结构本身与表结构类似,修改数据也会导致对应的数据表中的数据被修改。

4. 索引

索引(index)建立在已存在的数据表的列上,有利于提高数据查询的速度,也可以起到数据约束的作用。

5. 序列

序列(sequence)是定义的一组数,主要用于生成自增主键,在某些DBMS中会被淡化(如MySQL),由数据库自行管理。在有些DBMS中可以自行定义(如Oracle),设定起始数据、增长步长等,可以结合触发器使用。

6. 触发器

触发器(trigger)相当于一个预定义的命令,可以定义在某些动作发生时(数据插入、更改、删除等)执行。

7. 函数

函数(function)用于辅助完成较为复杂,或有参数参与的操作,一般必须有return子句,可以当做表达式出现在select中。

8. 存储过程

存储过程(procedure)与函数的功能类似,在存储过程中不使用return语句,在调用方式上也略有不同。

9. 用户

用户(user)在数据库中的作用主要为了能够更加细致的划分权限,用户名和密码的使用也能提高安全性。

三、CREATE

CREATE可用于创建数据库对象,结合相应的关键字使用。

1. 创建数据表

创建数据表时主要需要声明:数据表名称、数据列名、数据列的类型。

CREATE TABLE `表名` (`列名` 列的类型,...`列名` 列的类型
)

2. 创建视图

创建视图时,需要指定视图名称,并且需要指定查询语句。

CREATE VIEW `视图名称` AS 查询语句

3. 创建索引

索引是作用在某一个数据表的列上的,不同的索引类型有不同的关键字,以普通索引为例。

CREATE INDEX `索引名称` ON 表名(列名,...)

四、DROP

使用DROP删除时会直接删除数据库对象的结构。

1. 删除数据表

删除数据表时,会连同删除已存储的数据。

DROP TABLE `表名`

2. 删除视图

DROP VIEW `视图名称`

3. 删除索引

DROP INDEX `索引名称` ON `表名`

扫描下方二维码,加入官方粉丝微信群,可以与我直接交流,还有更多福利哦~

在这里插入图片描述


http://chatgpt.dhexx.cn/article/pV650Nw8.shtml

相关文章

Oracle的DDL数据定义操作

文章目录 1.数据定义语言DDL2.显示表结构3.数据类型4.新建表(create table)4.1建表规则4.2语法4.3default值4.4示例与注释4.5使用子查询创建表 5.修改表结构(alter table)5.1语法说明5.2示例5.2.1追加一个新列5.2.2修改一个列5.2.3删除一个列5.2.4重命名一个列 5.3清空表(trunc…

Mysql的基本用法和函数

学习网站 mysql研究院:http://wp1i.cn/archives/76063.html 函数 Mysql同步方式 semi replication//待定 批量插入数据的问题 show variables like %max_allowed_packet% 批量插入的数据过大,会报错,PacketTooBigException 使用时间分…

MySQL中DML语句和事务的概念

ML语句 知识要点 DML语句 插入行到表中 删除表中的行 更新表中的行 控制事务 DML语句 DML:DATA MANIPULATION LANGUAGE(数据操纵语言),由INSERT、UPDATE、DELETE等语句构成,用来修改表中的数据 INSERT语句 1.…

MySQL基础——DDL、DML、DQL、DCL语句

当成功安装数据库之后,对于数据库进行的简单且基础的操作 打开数据库操作 1、在运行中输入services.msc 会打开如下界面 可以选择对MySQL进行开启或者关闭 2、也可以使用命令指示符 命令提示符要用管理员身份运行 输入命令 net start [自己设置的数据库名称] …

Oracle DB 使用DDL语句创建和管理表

• 对主要的数据库对象进行分类 • 查看表结构 • 列举列可以使用的数据类型 • 创建简单的表 • 说明创建表时如何创建约束条件 • 描述方案对象如何工作 • 数据库对象 – 命名规则 • CREATE TABLE语句: – 访问另一个用户的表 – DEFAULT选项 • 数据类型 • 约束条件概览…

C++值传递和引用传递的区别

c中参数传递的区别: 1.值传递: 可以想象改变的只是实参的“替身”的值,而实参本身不会被改变。 值传递:将实参的值传递给形参;形参是实参的“替身”,但与实参本质上不是“同一个人”,只是值复…

Java值传递和引用传递基础分析

(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/77688416冷血之心的博客) 一年前我总结过一篇博客:Java基础之引用(String,char[],Integer&#x…

C#中的值传递和引用传递

在C#语言中,传递参数的方式有两种:值传递和引用传递。 在介绍这两种参数传递方式我们先简单理解一下值类型和引用类型。 在C#语言中的char,int,short,long,byte,float,double,boolean类型都是值类型,另外enum枚举类型和struct结构类型也是值…

Python值传递和引用传递(详细分析)

目录 1. 形参与实参 2. Python的数据类型 3.Python变量及其赋值 3.1 不可变对象赋值 3.2 可变对象赋值 3.3 变量删除 3.4 变量赋值总结 4.Python函数的参数传递 4.1 参数传递定义 4.2 不可变对象的参数传递 4.3 可变对象的参数传递 5.总结 6 不可变与可变对象赋值对…

Java值传递和引用传递详细说明(详细分析)

1. 形参与实参 我们先来重温一组语法: 形参:方法被调用时需要传递进来的参数,如:func(int a)中的a,它只有在func被调用期间a才有意义,也就是会被分配内存空间,在方法func执行完成后&#xff0…

Java中是值传递和引用传递

值传递 / 引用传递 值传递:就是在方法调用的时候,实参是将自己的一份拷贝赋给形参,在方法内,对该参数值的修改不影响原来的实参。 引用传递:是在方法调用的时候,实参将自己的地址传递给形参,此…

Java的值传递和引用传递

Java的值传递和引用传递 值传递:对形参的修改不会影响到实参 。引用传递:对实参的修改能够影响到实参 **Java是值传递:如果是基本数据类型,就是复制一份值传递给形参;如果是引用类型,那就将引用复制一份&…

Java 值传递和引用传递

值传递:在调用函数的时候,将实际参数复制一份传递到函数中,这样在函数中对参数进行修改的时候,就不会影响到原来的实际参数 引用传递:在调用函数的时候,将实际参数的地址直接传递函数中,这样在函数中对参数进行修改的时候,就会影响到实际参数值传递 引用传递…

go 语言值传递和引用传递

值传递 普通的值传递 package main import "fmt" func main(){fmt.Println(Hello("hello"," fpp")); } func Hello(stringName string,stringName2 string)(string){return stringNamestringName2; }string类型是引用传递吗? package main i…

Java 的值传递和引用传递

一、概述 Java数据类型分为基本类型和引用类型。相应的,变量也有两种类型:基本类型和引用类型。 1️⃣基本类型的变量保存原始值,即它代表的值就是数值本身。包含: 整型:byte,short,int&#…

java值传递和引用传递(附实例)

java值传递和引用传递(附实例) 1.数据类型1.1 基本数据类型1.2 引用数据类型 2.形参与实参2.1 函数中使用2.2 调用 3.值传递和引用传递3.1 定义3.2 例子3.3 结论 观前提示: 本文所使用的IDEA版本为ultimate 2019.1,JDK版本为1.8.…

java中的值传递和引用传递

个人理解,可能会有错误之处,请仔细甄别,谨慎参考!如有错误或不同见解请指出! 值传递(Pass By Value或者Call By Value)是对基本型变量而言的,传递的是该变量的一个副本,改变副本不影响原变量。…

【JAVA】值传递与引用传递

一.声明 Java中没有引用传递 二.值传递和引用传递 值传递:就是在方法调用的时候,实参是将自己的一份拷贝赋给形参,在方法内,对该参数值的修改不影响原来的实参。 引用传递:是在方法调用的时候,实参将自…

值传递与引用传递详解

1、关于值传递 值传递:是指在调用函数时,将实际参数复制一份传递到函数中,这样在函数中如果对参数进行修改,就不会影响到实际参数 如下图所示,当传递参数之前会将参数进行复制,函数中修改了参数&#xff0c…

值传递与引用传递的区别

一、值传递:是指在调用函数时将实际参数复制一份传递到函数中,这样在函数中如果对参数进行修改,将不会影响到实际参数。 ​ 代码在内存中的执行流程: 1、首先加载main方法; ​ 2、接下来int number 100&#xff1…