SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

算法漫游
• 阅读 297

DDL(Data Definition Language),是用于描述数据库中要存储的现实世界实体的语言。前面我们介绍了数据库及SQL语言的相关概念和基础知识,本篇文章我们来重点讲述DDL(数据定义语言的语法格式)的相关内容以及DDL的常用语句。

一、DDL介绍

这里我们先回顾一下前面讲过的SQL语言的概念:SQL(Structured Query Language),即结构化查询语言,是在关系型数据库(诸如Mysql、SQL Server、Oracle等)里进行相关操作的标准化语言,可以根据sql的作用分为以下几种类型:
SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!
下面再来看DDL语言是什么:
DDL,全称为Data Definition Language,即数据定义语言。它是SQL语言的重要组成部分,主要用于定义和管理数据库的结构。

二、DDL语言能做什么?

通过DDL,我们可以创建、修改和删除数据库、表、视图等对象。

  • 创建数据库: 使用CREATE DATABASE语句,我们可以创建一个新的数据库。
  • 删除数据库: 使用DROP DATABASE语句,我们可以删除一个已经存在的数据库。
  • 创建表: 使用CREATE TABLE语句,我们可以在数据库中创建新的表。
  • 删除表:使用DROP TABLE语句,我们可以删除一个已经存在的表。
  • 修改表结构: 使用ALTER TABLE语句,我们可以修改已经存在的表的结构,如添加、删除或修改字段等。

三、什么是数据库对象

数据库对象是数据库的组成部分,常见的有以下几种:
1、表(Table )
数据库中的表与我们日常生活中使用的表格类似,它也是由行(Row) 和列(Column)组成的。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

列由同类的信息组成,每列又称为一个字段,每列的标题称为字段名。行包括了若干列信息项。一行数据称为一个或一条记录,它表达有一定意义的信息组合。一个数据库表由一条或多条记录组成,没有记录的表称为空表。每个表中通常都有一个主关键字,用于唯一确定一条记录。

编程学习,从云端源想开始,课程视频、在线书籍、在线编程、一对一咨询……你想要的全部学习资源这里都有,重点是统统免费!点这里即可查看

2、索引(Index)
索引是根据指定的数据库表列建立起来的顺序。它提供了快速访问数据的途径,并且可监督表的数据,使其索引所指向的列中的数据不重复。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

3、视图(View)
视图看上去同表似乎一模一样,具有一组命名的字段和数据项,但它其实是一个虚拟的表,在数据库中并不实际存。视图是由查询数据库表产生的,它限制了用户能看到和修改的数据。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

4、图表(Diagram)
图表其实就是数据库表之间的关系示意图。利用它可以编辑表与表之间的关系。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

5、缺省值(Default)
缺省值是当在表中创建列或插入数据时,对没有指定其具体值的列或列数据项赋予事先设定好的值。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

6、规则(Rule)
规则是对数据库表中数据信息的限制,它限定的是表的列。

7、触发器(Trigger)
触发器是一个用户定义的SQL事务命令的集合。当对一个表进行插入、更改、删除时,这组命令就会自动执行。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

8、存储过程(Stored Procedure)
存储过程是为完成特定的功能而汇集在一起的一组SQL 程序语句,经编译后存储在数据库中的SQL程序。

SQL中的DDL(数据定义)语言:掌握数据定义语言的关键技巧!

9、用户(User)
所谓用户就是有权限访问数据库的人。

四、DDL常用语句

4.1 数据库相关

1)查看所有数据库
格式:show databases;

2)创建数据库
格式:create database 数据库名 charset=utf8;
举例:

#创建一个名为test的数据库
#create database 库名;
create database test;
#创建一个名为test的数据库并指定字符集和编码格式
create database test default charset utf8 collate utf8_general_ci;

3)查看数据库信息
格式:show create database 库名;

4)删除数据库

格式:drop database 数据库名;

举例:

#删除test数据库
drop database test;

5)使用数据库

执行表相关和数据库相关的SQL语句之前必须先使用了某个数据库

格式:use 数据库名;

举例:

use test;

4.2 表相关

1)创建表
格式:create table 表名(字段1名 类型,字段2名 类型,…)
举例:

create table person(name varchar(50),age int);
create table person(name varchar(50),age int);
create table stydent(name varchar(50),chinese int ,math int, english int)charset=utf8;
创建一个员工表emp 保存名字,工资和工作
create table emp(name varchar(50),salary int,job varchar(20));

2)查询所有表
格式:show tables;

3)查询表信息
格式:show create table 表名;
举例:

show create table emp;

4)查询表字段
格式:desc 表名; (description)

5)修改表名
格式:rename table 原名 to 新名;
举例:

rename table stydent to stu;

6)删除表
格式:drop table 表名;

4.3 alter表操作相关

1)添加表字段
格式(最后面添加):alter table 表名 add 字段名 类型;
格式(最前面添加):alter table 表名 add 字段名 类型 first;
在xxx字段后面添加:alter table 表名 add 字段名 类型 after 字段名;
举例:

alter table emp add gender gender varchar(5);
alter table emp add id int first;
alter table emp add dept varchar(20) after name;

2)删除表字段
格式:alter table 表名 drop 字段名;
举例:

alter table emp drop dept;

3)修改表字段
格式:alter table 表名 change 原名 新名 新类型;
举例:

alter table emp change job dept varchar(10);

4)修改列属性
格式:alter table 表名 modify 列名 新列属性
举例(只有MySQL是这样写的):

alter table student modify age int;

关于DDL常用语句就讲这么多了,尽管现在有许多图形化工具可以替代传统的SQL语句进行操作,同时在Java等语言中也可以使用数据库,但对于SQL各类语句的了解仍然非常重要。

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
MySQL的sql语言分类DML、DQL、DDL、DCL、
SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL1.数据定义语言DDL(DataDefinitionLanguage)  对象:数据库和表  关键词:createalterdroptruncate(删除当前表再新建一个一模一样的表结构)  创建数据库:create
Wesley13 Wesley13
3年前
MySQL学习——操作表
MySQL学习——操作表摘要:本文主要学习了使用DDL语句操作表的方法。创建表语法1createtable表名表定义选项表选项;表定义选项用来创建定义表的结构,由列名(col\_name)、列的定义(column\_definition)以及可能的空值说明、完
Wesley13 Wesley13
3年前
mysql中的DDL,DML,DQL,DCL
SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL  1.数据定义语言DDL(DataDefinitionLanguage)  对象:数据库和表  关键词:createalterdroptruncate(删除当前表再新建一个一模一样的表结构)  创建数据库:createda
Wesley13 Wesley13
3年前
Oracle总结【视图、索引、事务、用户权限、批量操作】
前言在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了...那么本篇主要总结关于Oralce视图、序列、事务的一些内容...在数据库中,我们可以把各种的SQL语句分为四大类...(1)DML(数据操纵语言):select,insert,update,delete(2)DDL(数据
Wesley13 Wesley13
3年前
mysql常用基本操作
MySQL数据库SQL(StructuredQueryLanguage)结构化查询语言常用基本操作: /\DDL(DataDefinitionLanguage)数据定义语言\/  创建数据库:  createdatabase'数据库名称'charsetutf8;  删除数据库:  dropdat
Wesley13 Wesley13
3年前
Oracle 了解 DDL 操作与 REDO 的关系
了解DDL操作与REDO的关系\TOC\DDL是否会产生REDO用到的SQL:查看redo的大小SQLselectb.name,a.valuefromv$mystata,v$statnamebwherea.statistic
Wesley13 Wesley13
3年前
Mysql之常用sql总结
下面是我总结的Mysql中常用的一些SQL,一般分为下面三种:DDL:DataDefinitionLanguage,数据定义语言,这些语句操作的是数据库对象,比如:定义了数据库、表、列、索引等。常用的关键字包括:create、drop、alter等。DML:DataManipulationLanguage,数据操作语句,用于添加、更新、删除、
Wesley13 Wesley13
3年前
MySQL数据库之DDL(数据定义语言)
1.MySQL数据库之DDL创建、删除、切换(1)查看所有数据库showdatabases;(2)切换数据库use数据库名;(3)创建数据库createdatabase数据库名;(4)删除数据库dropdatabase数据库名;2.My