SQl DDL-数据库的创建

2024-08-25 13:38

本文主要是介绍SQl DDL-数据库的创建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    SQL Server 语言由四部分构成:SQL DDL(Data Definition Language 数据定义语言),SQL DML(Data Manipulation Language 数据操纵语言),SQL DCL(Data Control Language 数据控制语言),嵌入式SQL语言。

    DDL ,用于定义数据库、基本表、视图、索引等结构。也就是数据库、基本表等的创建、撤销以及修改等操作的语言。几个句子有固定的语法,因为SQL 语言经过发展已近丢掉了一些数学符号,采用英语单词表示和结构式的语法规则,看起来很像英语句子,阅读起来很容易,下面就介绍一下DDL都包括哪几个基本语句。

数据库

1.1创建:create database

   create database<数据库名> authorization<创建者用户名>

   创建一个叫什么名字,创建者是谁谁的数据库。一个数据库由数据库名称和数据库拥有者名称或账号来确定,并包含数据库中每一个元素的定义。创建一个数据库,就是定义了一个存储空间。申请了一个空间,准备要录入数据。

1.2撤销:drop

   drop database<数据库名>[cascade|restrict]

   cascade、restrict是什么意思?下边一起介绍。

   

数据库是通俗的叫法,学术一点的叫法是SQL模式,它与上边一套是等价的。

2.1创建 create schema

   create schema<SQL 模式名>authorization<用户名>
2.2撤销 drop
   drop schema<数据库名>[cascade|restrict]
基本表
创建:create table
create table<基本表名>
(<列名 类型>,
 ......
 <完整性约束>,
 ...... )
 
三种完整性约束子句:
   primary key(主键子句);
   foreign key(外键子句);
   check(检查子句).
   每个基本表的创建定义中包含了若干列的定义和若干个完整性约束。(也就是每个表创建时要说明每一列的名称和类型,以及这一列是否是主键,外键或检查子句)
完整性约束子句举例:
   not null;
   primary key(主键列名);
   foreign key(外键名) references 基本表A名(基本表A主键名);表示一个基本表的外键与基本表A中的主键对应。
修改表结构:
        增加新列: alter....add....
           alter table<基本表名>add<列名><类型>,
        删除原有列: alter...drop...
           alter table<基本表名>drop<列名>[cascade|restrict]
        修改原有列的类型、宽度: alter...modify...
           alter table<基本表名>modify<列名><类型>
撤销:drop table
       drop table<基本表名>[cascade|restrict]
 
索引
    索引是关键码的前身,属于物理存储的路径概念(操作系统存储管理中有提到索引表),而不是逻辑的概念。引入主键概念,把数据库的物理结构和逻辑结构分开来了。但目前大多数关系DBMS还使用索引机制,其功能仅限于查询时起作用。
创建: create index
    create[unique]index<索引名>on<基本表名>(<列名序列>)
    unique表示每个索引值对应唯一的数据记录。
     一个索引键可以对应多个列,索引排列时可以升序,也可以降序,升序排列用ASC表示,降序排列用DESC表示。(机房收费系统中查询结果显示的时候用到了)
撤销: drop index
    drop index<索引名>
cascade&restrict:
   数据库的删除语句以及基本表的删除语句中都有这两个词。他们是什么意思呢?
   cascade(级联式)方式:执行DROP语句时,把SQL模式及其下属的基本表、视图、索引等所有元素全部撤销。
   restrict(约束式)方式:执行DROp语句时,只有当SQL模式(数据库)下没有任何下属元素时,才能撤销数据库,否则拒绝执行DROP语句。只有在没有视图或约束引用要删除的基本表时才能撤销(基础系统里的表用的就是约束式方式)
   比较来说,级联式语句删除地更彻底,是摧毁式的删除。约束式语句则受数据库和基本表包含元素的限制,当删除之前,它会先检查有没有,避免了不必要的误删。数据无价,删除需谨慎。
总结
几个动词总结下来就是create(增)、alter(改)、drop(删)。正好是数据定义语言的核心所在,数据定义语言就是对数据结构进行操作的语言。又复习了一遍这些基本语句,接下来就实战了。
 

这篇关于SQl DDL-数据库的创建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1105710

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多