一、数据定义语言(Data Definition Language)的基本操作

定义数据库、表等,包括CREATE语句、ALTER语句、DROP语句。CREATE语句用于创建数据库、数据表等,ALTER语句用于修改表的定义等,DROP语句用于删除数据库、删除表等
# 查看所有数据库名称:
show databases; # 切换数据库;切换到test数据库:
use information_schema; # 显示所有表:
show tables; # 查询表内容:
select * from CHARACTER_SETS;

二、DDL数据库的操作

2.1 创建数据库

CREATE DATABASES 库名字 CHARSET 字符集;

# 规范:关键字一般大写,库名字小写,使用utf8字符集
CREATE DATABASE testdb charset utf8; # 如果这个数据已经存在,那么会报错database exists
create database student;
# 如果不存在创建,存在就不创建!
create database if not exists student;

忽略大小写参数:可以设置MySQL忽略大小写(全部变成小写),设置前提,是在规划数据库时就加上。如果后期加上,可能会导致use不到大写的库。

show variables like '%lower%';
# 将值设置为1,忽略大写小
lower_case_table_names = 1

2.2 删除数据库

DROP DATABASE student;
# 如果存在删除,不存在就不删除
drop database if exists student;
# 删除名为test999的数据库。如果这个数据库不存在,那么会报错 database doesn't exist
drop database student;

2.3 修改数据库的字符集

注意:修改后的字符集必须是前者的严格超集。修改有风险,编码不匹配会出现乱码。

ALTER DATABASE student CHARSET utf8mb4;

三、DDL表的定义

3.1 创建表的语法

help create table;

创建表 CREATE TABLE 表名
(
字段名1,数据类型[完整性约束条件],
字段名2,数据类型[完整性约束条件],
...
字段名n,数据类型[完整性约束条件]
);

3.2数据类型

数值类型

日期和时间类型

字符串类型

3.3 约束条件

PRIMARY KEY    # 主键约束,用于唯一标识对应的记录
FOREING KEY    # 外键约束
NOT NULL # 非空约束
UNIQUE      # 唯一性约束
DEFAULT # 默认值约束,用于设置字段的默认值

3.4 示例

use webdb;
-- DROP TABLE t1;
CREATE TABLE t1 (id INT NOT NULL AUTO_INCREMENT PRIMARY KEY COMMENT '学生ID',
NAME VARCHAR(20) NOT NULL COMMENT '学生姓名',
age TINYINT COMMENT '学生年龄',
gender ENUM('m','f') NOT NULL DEFAULT 'm' COMMENT '学生性别',
birthday DATETIME DEFAULT NOW() COMMENT '入学时间',
telnum varchar(12) NOT NULL UNIQUE COMMENT '手机号码');

3.5 查看表及表结构

# 查看所有表
SHOW TABLES; # 查看t1表结构
DESC t1; # 查看创建表语句
show create table t1;

3.7 修改表名

# 将t1表名称修改为frist_grade
ALTER TABLE t1 RENAME frist_grade;

3.8  修改字段名称

# 修改字段名 ALTER TABLE 表名 CHANGE 旧字段名 新字段名 新数据类型;
ALTER TABLE frist_grade CHANGE birthday bir datetime DEFAULT CURRENT_TIMESTAMP COMMENT '入学时间';

3.9 修改字段类型

# 修改字段的数据类型 ALTER TABLE 表名 MODFIY 字段名 数据类型;
# 将NAME的长度修改为30
ALTER TABLE frist_grade MODIFY NAME varchar(30);

3.10 添加字段

# 添加字段 ALTER TABLE 表名 ADD 新字段名 数据类型;

# 在表的末尾增加一列
ALTER table frist_grade ADD wechat VARCHAR (20) NOT NULL UNIQUE; # 指定位置添加列,在birthday后面添加一个email列
ALTER TABLE frist_grade ADD email VARCHAR(50) NOT NULL AFTER birthday; # 在第一列位置,添加idcard列
ALTER TABLE frist_grade ADD idcard VARCHAR(20) not NULL FIRST;

3.11 删除字段列

一定要认真审核,反复和开发人员确认,删除列时,会将此列原有数据全部清除掉。删除之前要备份

# 删除字段 ALTER TABLE 表名 DROP 字段名;
ALTER TABLE frist_grade DROP hobby;

3.12 删除表

DROP TABLE frist_grade;

DDL(数据库定义语言)(五)的更多相关文章

  1. 数据库基础之一--DDL(数据库定义语言),DCL(数据库控制语言)

    Mysql是一个非常典型的C/S结构的应用模型,所以Mysql连接必须依赖于一个客户端或者驱动. 在linux中支持两种连接模式:TCP/IP模式和socket SQL语句的四部分: DDL:数据定义 ...

  2. MySQL进阶11--DDL数据库定义语言--库创建/修改/删除--表的创建/修改/删除/复制

    /*进阶 11 DDL 数据库定义语言 库和表的管理 一:库的管理:创建/修改/删除 二:表的管理:创建/修改/删除 创建: CREATE DATABASE [IF NOT EXISTS] 库名; 修 ...

  3. 第一天,Mysql安装,DDL(数据库定义语言),DBA,DML(数据库操纵语言),导入外面的sql文件

    把“D:\mysql-5.6.22-winx64\bin”添加到系统环境变量path中了,然后在任意目录可访问mysql等命令,这样如登录等操作就不需要进入MySQL安装目录才好执行! MySQL下载 ...

  4. Hive 官方手册翻译 -- Hive DDL(数据定义语言)

    Hive DDL(数据定义语言) Confluence Administrator创建, Janaki Lahorani修改于 2018年9月19日 原文链接 https://cwiki.apache ...

  5. sql 两大类 DDL数据定义语言 和DCL数据控制语言

    SQL分为五大类: DDL:数据定义语言   DCL:数据控制语言     DML:数据的操纵语言  DTL:数据事务语言  DQL:数据查询语言. DDL (date definition lang ...

  6. mysql DDL数据定义语言

    DDL数据定义语言 本节涉及MySQL关键字:create.alter(rename,add,chang,modify,drop).drop.delete.truncate等. -- 创建表:-- 数 ...

  7. DDL数据定义语言

    DDL数据定义语言 (一)概述 DDL(Data Definition Language):数据定义语言,用来定义数据库对象,库.表.列等:创建.删除.修改 库,表结构.主要分为操作数据库的DDL和操 ...

  8. oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言

    DCL 数据控制语言 Data control language 之前说过的授权和收权利语句 grant, revoke DDL 数据定义语言 Data define language create ...

  9. Oracle language types(语言种类) 表的相关操作 DDL数据定义语言

    数据定义语言 Data Definition Language Statements(DDL)数据操纵语言 Data Manipulation Language(DML) Statements事务控制 ...

随机推荐

  1. 学习-angular 7入门

    1.安装脚手架:npm install -g @angular/cli 安装之后,输入命令 ng v: Package Version -------------------------------- ...

  2. GDB 调试C++

    原来比较熟悉用gdb调试C程序,没有用过gdb调试C++程序,原理上没有什么区别.在形式上有一些区别,因为C++支持名字空间和class等机制,把函数的可见域做了隔离. 拿envoy的代码作个例子: ...

  3. [RN] windows7 安装 Realm Studio 后,打开报错 A JavaScript error occurred in the main process

    windows7  安装 Realm Studio 后,打开报错 报错如下: A JavaScript error occurred in the main process Uncaught Exce ...

  4. 【转】K-Means聚类算法原理及实现

    k-means 聚类算法原理: 1.从包含多个数据点的数据集 D 中随机取 k 个点,作为 k 个簇的各自的中心. 2.分别计算剩下的点到 k 个簇中心的相异度,将这些元素分别划归到相异度最低的簇.两 ...

  5. 关于gcd

    内容: \(gcd(a,b)=gcd(b,a\% b)\) 用途: 这不废话嘛,当然是用来求最大公约数啊 证明:(这还是四月份的时候cdx巨佬给我讲的qwq) 设\(d=gcd(a.b)\) 则有\( ...

  6. 第02组 Beta冲刺(1/4)

    队名:十一个憨批 组长博客 作业博客 组长黄智 过去两天完成的任务:了解整个游戏的流程 GitHub签入记录 接下来的计划:继续完成游戏 还剩下哪些任务:完成游戏 燃尽图 遇到的困难:没有美术比较好的 ...

  7. MySQL实战45讲学习笔记:第十九讲

    一.引子 一般情况下,如果我跟你说查询性能优化,你首先会想到一些复杂的语句,想到查询需要返回大量的数据.但有些情况下,“查一行”,也会执行得特别慢.今天,我就跟你聊聊这个有趣的话题,看看什么情况下,会 ...

  8. [LeetCode] 138. Copy List with Random Pointer 拷贝带有随机指针的链表

    A linked list is given such that each node contains an additional random pointer which could point t ...

  9. 第27课 “共享状态”及其管理者(std::future/std::shared_future)

    一. “共享状态” (一)“共享状态”对象 1. 用于保存线程函数及其参数.返回值以及新线程状态等信息.该对象通常创建在堆上,由std::async.std::promise和std::package ...

  10. 使用JDBC连接MySQL数据库操作增删改查

    目录 1.首先这个Myeclipse的包名以及一些实现的类(这样子写是我的习惯) 2.接下来我们创建数据库(MySQL) 3.在数据库里面添加数据 4.首先是BaseDao,这个是重中之重,注意那个数 ...