菜鸟之路Day29一一MySQL之DDL

菜鸟之路Day29一一MySQL之DDL

作者:blue

时间:2025.5.2

文章目录

0.概述

文章内容学习自黑马程序员BV1m84y1w7Tb

何为DDL?

答:DDL即数据定义语言,用来定义数据库对象(数据库,表,字段)

注意单条SQL语句结尾要使用分号来标记

1.DDL之数据库操作

1.1查询

查询所有数据库

sql 复制代码
show databases;

查询当前正在使用的数据库

sql 复制代码
select database();

1.2创建

创建数据库

sql 复制代码
create database [if not exists] 数据库名;

1.3使用

使用某个数据库

sql 复制代码
use 数据库名;

1.4删除

删除数据库

sql 复制代码
drop database [if exists] 数据库名; 

2.DDL之表操作

2.1创建表

sql 复制代码
create table 表明{
	字段1 字段类型 [约束] [comment 字段1注释],
	......
	字段n 字段类型 [约束] [comment 字段n注释]
}[comment 表注释];

约束

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据

目的:保证数据库中数据的正确性,有效性和完整性

约束 描述 关键字
非空约束 限制该字段值不能为null not null
唯一约束 保证字段的所有数据都是唯一的,不重复的 unique
主键约束 主键是一行数据的唯一标识,要求非空且唯一 primary key (auto_increment自增)
默认约束 保存数据时,如果未指定该字段值,则采用默认值 default
外键约束 让两张表的数据建立连接,保证数据的一致性和完整性 foreign key

示例:

sql 复制代码
create table tb_user(
    id int primary key auto_increment comment 'id,唯一标识',
    username varchar(50) not null unique comment '用户名',
    name varchar(15) not null comment '姓名',
    age int comment '年龄',
    gender char(1) default '男' comment '性别'
)comment '用户表';

2.2数据类型

数值类型:

字符串类型:

char(10):最多只能存10个字符,不足10个字符,占用10个字符空间

varchar(10):最多只能存10个字符,不足10个字符,按照实际长度存储

日期时间类型:

2.3查询表

sql 复制代码
查询当前数据库所有表:show table;

查询表结构:desc 表名;

查询建表语句:show create table 表名;

2.4修改表结构

sql 复制代码
添加字段:alter table 表名 add 字段名 类型(长度)[comment 注释][约束];

修改字段类型:alter table 表名 modify 字段名 新数据类型(长度);

修改字段名和字段类型:alter table 表名 change 旧字段名 新字段名 类型(长度)[comment 注释][约束];

删除字段:alter table 表名 drop column 字段名;

修改表名: rename table 表名 to 新表名;

示例:

sql 复制代码
alter table tb_user add qq_num varchar(10) comment 'QQ号码';

alter table tb_user modify qq_num varchar(11);

alter table tb_user change qq_num qq varchar(12) comment 'QQ号码';

alter table tb_user drop column qq;

rename table tb_user to user

2.5删除表

sql 复制代码
删除表:drop table [if exists] 表名;
相关推荐
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北1 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip