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

相关文章

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更