前面的文章一直都在讲述关于DML方面的SQL Statement。这篇文章来说说表方面的DDL:

  • CREATE 创建表
  • ALTER 修改表
  • DROP 删除表

CREATE

1.语法
  1. CREATE TABLE [IF NOT EXISTS] table_name (
  2. column1_name 类型,
  3. column2_name 类型,
  4. [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name (columnJ[length][ASC|DESC]),
  5. [CONSTRAINT constraint_name PRIMARY KEY (columnJ,...)],
  6. [CONSTRAINT constraint_name FOREIGN KEY (columnJ,...) REFERENCES talbe_name (columnK,...)]
  7. ) [COMMENT "xxxx"];

大致的语法如上,对于不同的数据库的CREATE语法还不尽相同,有特定的参数。比如Mysql中可以创建表时,指定字符编码、存储引擎等。

2.示例

  1. CREATE TABLE IF NOT EXISTS student (
  2. id varchar(18) NOT NULL UNIQUE,
  3. name varchar(10) NOT NULL,
  4. INDEX idx_name (name(5) DESC),
  5. PRIMARY KEY (id);
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT "学生表";

####ALTER

1.语法
  1. -- 增加表列、索引
  2. ALTER TABLE table_name
  3. ADD [COLUMN] cloumnJ 类型,
  4. ADD {INDEX|KEY} index_name (columnJ[length][ASC|DESC]);
  5. -- 删除表的列、索引、主键、外键
  6. ALTER TABLE table_name
  7. DROP [COLUMN] cloumnJ,
  8. ADD {INDEX|KEY} index_name,
  9. DROP PRIMARY KEY,
  10. DROP FOREIGN KEY fk_symbol;

修改表非常复杂,不同的数据库也不一样,不过大多数情况下可以参考文档,如Mysql可以参考:

Data Definition Statements

2.示例
  1. ALTER TABLE student ADD COLUMN age smallint NOT NULL;

####DROP

1.语法
  1. DROP TABLE [IF EXISTS] table_name [, tbl_name] ...

SQL系列(十三)—— 关于表的DDL的更多相关文章

  1. SQL Server 临时表和表变量系列之选择篇

    原文地址:https://yq.aliyun.com/articles/69187 摘要: # 摘要 通过前面的三篇系列文章,我们对临时表和表变量的概念.对比和认知误区已经有了非常全面的认识.其实,我 ...

  2. Influx Sql系列教程三:measurement 表

    在influxdb中measurement相当于mysql中的表,可以理解为一条一条记录都是存与measurent中的,一个数据库中可以有多个measurement,一个measurement中可以存 ...

  3. 【SQL系列】从SQL语言的分类谈COMMIT和ROLLBACK的用法

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[SQL系列]从SQL语言的分类谈COMMIT和 ...

  4. sql语句中----删除表数据drop、truncate和delete的用法

    sql语句中----删除表数据drop.truncate和delete的用法 --drop drop table  tb   --tb表示数据表的名字,下同 删除内容和定义,释放空间.简单来说就是把整 ...

  5. .Net程序员学用Oracle系列(6):表、字段、注释、约束、索引

    <.Net程序员学用Oracle系列:导航目录> 本文大纲 1.表 1.1.创建表 1.2.修改表 & 删除表 2.字段 2.1.添加字段 2.2.修改字段 & 删除字段 ...

  6. 第16课-数据库开发及ado.net-数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍

    第16课-数据库开发及ado.net 数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍 SQL语句入门(脚本.命令) SQL全名是结构化查询语言(Structur ...

  7. SQL中的四种语言DDL,DML,DCL,TCL

    1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...

  8. SQL server 数据库用户表名称

    转自(http://blog.163.com/jlj_sk/blog/static/22579293200861422833924/) 取得SQL server 数据库中 所有用户表名称 select ...

  9. SQL的四种语言:DDL、DML、DCL、TCL

    1. DDL(Data Definition Language) 数据库定义语言statements are used to define the database structure or sche ...

  10. Influx Sql系列教程九:query数据查询基本篇二

    前面一篇介绍了influxdb中基本的查询操作,在结尾处提到了如果我们希望对查询的结果进行分组,排序,分页时,应该怎么操作,接下来我们看一下上面几个场景的支持 在开始本文之前,建议先阅读上篇博文: 1 ...

随机推荐

  1. <Android Studio> 3.打包APK

    我的IDE版本是 3.5 我希望输出的apk文件格式是: 名称_v版本_release/debug_日期 时间.apk 步骤: 1.打开build.gradle 末尾添加如下代码 def releas ...

  2. 使用 Python 生成二维码

    在“一带一路”国际合作高峰论坛举行期间, 20 国青年投票选出中国的“新四大发明”:高铁.扫码支付.共享单车和网购.其中扫码支付指手机通过扫描二维码跳转到支付页面,再进行付款.这种新的支付方式,造就二 ...

  3. Spring Boot集成Druid数据库连接池

    1. 前言 Druid数据库连接池由阿里巴巴开源,号称是java语言中最好的数据库连接池,是为监控而生的.Druid的官方地址是:https://github.com/alibaba/druid 通过 ...

  4. SpringBoot 整合websocket

    1.MyWebSocket package org.hxm.webSocket; import java.io.IOException; import java.util.concurrent.Cop ...

  5. rhel7学习第五天

    管道命令符的功能的确强大!

  6. 201671030113 李星宇 实验十四 团队项目评审&课程学习总结

    项目 内容 所属课程 [所属课程(https://www.cnblogs.com/nwnu-daizh/) 作业要求 作业要求 课程学习目标 (1)掌握软件项目评审会流程:(2)反思总结课程学习内容 ...

  7. Nginx——端口负载均衡

    前言 Nginx做的代理后面SpringBoot的项目,1N3T的架构,Tomcat的配置也进行了相应的调优. 配置 这里主要来简单的说下Nginx的端口负载均衡,具体的大家可以参考 Nginx文档 ...

  8. Kinect for Windows V2开发教程

    教程 https://blog.csdn.net/openbug/article/details/80921437 Windows版Kinect SDK https://docs.microsoft. ...

  9. cube.js 最近的一些更新

    cube.js 是一个和不错的数据分析框架,最近又有了一些新的功能支持,以下是一些简单的 总结 基于web socket 的预览支持 react hooks api 支持 支持基于reecharts ...

  10. python相对导包问题

    导包分为:绝对路径.相对路径 在测试时发现不能够使用相对路径 查过之后才知道: 运行模块(如:main.py)中导包只能使用绝对路径,不能使用相对路径 官方文档: Note that relative ...