DDL——数据定义语言(Mysql学习笔记)

一:SQL语言概述

全称 Structured Query Language,结构化查询语言。操作关系型数据库的编程语言,定义了一套操作关系型数据库统一标准 。

1:SQL通用语法

①:SQL语句可以单行或多行书写,以分号结尾。

②:SQL语句可以使用空格/缩进来增强语句的可读性。

③:MySQL数据库的SQL语句不区分大小写,关键字建议使用大写

④:注释

  • 单行注释: - - 注释内容 或 # 注释内容
  • 多行注释:/* 注释内容 */

2;SQL分类

SQL语句,根据其功能,主要分为四类:DDL、DML、DQL、DCL。

分类全称说明
DDLData Definition Language数据定义语言,用来定义数据库对象(数据库,表,字段)
DMLData ManipulationLanguage数据操作语言,用来对数据库表中的数据进行增删改
DQLData Query Language数据查询语言,用来查询数据库中表的记录
DCLData Control Language数据控制语言,用来创建数据库用户、控制数据库的访问权限

二:SQL语言之DDL-定义数据库

数据库操作

Data Definition Language,数据定义语言,用来定义数据库对象(数据库,表,字段) 。

1:查询所有数据库

show databases ;

2:查询当前数据库

select database()

3:创建数据库

create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序规则 ] ;

在同一个数据库服务器中,不能创建两个名称相同的数据库,否则将会报错。
可以通过 if not exists 参数来解决这个问题,数据库不存在, 则创建该数据库,如果存在,则不创建。

4:删除数据库

drop database [ if exists ] 数据库名 ;

如果删除一个不存在的数据库,将会报错。此时,可以加上参数 if exists ,如果数据库存在,再执行删除,否则不执行删除。

5:切换数据库

use 数据库名 ;

我们要操作某一个数据库下的表时,就需要通过该指令,切换到对应的数据库下,否则是不能操作的。比如,切换到MyDatabase数据库,执行如下SQL:use MyDatabase;

数据表操作

1:查询当前数据库所有表

show tables;

比如,我们可以切换到sys这个系统数据库,并查看系统数据库中的所有表结构。

use sys;
show tables;

在这里插入图片描述

可以看到有很多表结构,因为sys是一个系统数据库

2:查询指定表结构

desc 表名 ;

通过这条指令,我们可以查看到指定表的字段,字段的类型、是否可以为NULL,是否存在默认值等信息。
在这里插入图片描述

3:查询指定表的建表语句

show create table 表名 ;

通过这条指令,主要是用来查看建表语句的,而有部分参数我们在创建表的时候,并未指定也会查询到,因为这部分是数据库的默认值,如:存储引擎、字符集等。
在这里插入图片描述

4:创建表结构

CREATE TABLE 表名(
字段1 字段1类型 [ COMMENT 字段1注释 ],
字段2 字段2类型 [COMMENT 字段2注释 ],
字段3 字段3类型 [COMMENT 字段3注释 ],
......
字段n 字段n类型 [COMMENT 字段n注释 ]
) [ COMMENT 表注释 ] ;

最后一个字段后面是没有逗号的!!!!!!
例如:我们创建一张表 tb_user ,对应的结构如下,那么建表语句为:
在这里插入图片描述

create table tb_user(
id int comment '编号',
name varchar(50) comment '姓名',
age int comment '年龄',
gender varchar(1) comment '性别'
) comment '用户表';

表操作

1:添加字段

ALTER TABLE 表名 ADD 字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];

例:为emp表增加一个新的字段”昵称”为nickname,类型为varchar(20)

ALTER TABLE emp ADD nickname varchar(20) COMMENT '昵称';

2:修改数据类型

ALTER TABLE 表名 MODIFY 字段名 新数据类型 (长度);

3:修改字段名和字段类型

ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型 (长度) [ COMMENT 注释 ] [ 约束 ];

例:将emp表的nickname字段修改为username,类型为varchar(30)

ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT '昵称';

4:删除字段

ALTER TABLE 表名 DROP 字段名;

例:将emp表的字段username删除

ALTER TABLE emp DROP username;

5:修改表名

ALTER TABLE 表名 RENAME TO 新表名;

例:将emp表的表名修改为 employee

ALTER TABLE emp RENAME TO employee;

6:删除表

DROP TABLE [ IF EXISTS ] 表名;

可选项 IF EXISTS 代表,只有表名存在时才会删除该表,表名不存在,则不执行删除操作(如果不加该参数项,删除一张不存在的表,执行将会报错)。

例;如果tb_user表存在,则删除tb_user表

DROP TABLE IF EXISTS tb_user

7:删除指定表, 并重新创建表

TRUNCATE TABLE 表名;
注意: 在删除表的时候,表中的全部数据也都会被删除。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值