MySQL中的DDL(一)

关于数据库,就需要先了解数据库、数据库管理系统和SQL。

  • 数据库是一个有组织地存储数据的仓库
  • 数据库管理系统是操纵和管理数据库的大型软件
  • SQL是操作关系型数据库的编程语言

而以上三者之间的关系就是SQL语言通过操作数据库管理系统来操作数据库。

SQL语言又分为,DDL、DML、DQL、DCL。

  • DDL:数据库定义语言,定义数据库对象(数据库,表,字段)
  • DML:数据库操作语言,对数据库表中的数据进行增删改
  • DQL:数据库查询语言,查询数据库中表的记录
  • DCL:数据库控制语言,创建数据库用户、控制数据库的访问权限

DDL-数据库操作

  • 查询所有数据库(即查询当前有哪些数据库)

  • show databases;

  • 查询当前数据库(即查询当前处于哪一个数据库中)

  • select database();

  • 创建数据库([ ] 中的数据可写可不写)

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

    例:create dabase if not exists test default utf8mb4;

  • 删除数据库

  • drop database [if exists] 数据库名;

    例:drop datase if exists test;

  • 使用数据库(切换数据库)

  • use 数据库名;

DDL-表操作-查询

  • 查询当前数据库所有表(即查询当前数据库中所有的表)

  • show tables;

  • 查询表结构 (即查询当前表中有哪些字段)

  • desc 表名;

    例:desc student;

  • 查询指定表的建表语句

  • show create table 表名;

    例:show create table student;

DDL-表操作-创建

  • create table 表名 (
    字段1 字段1类型 [ comment 字段1注释 ];
    字段2 字段2类型 [ comment 字段2注释 ];
    字段3 字段3类型 [ comment 字段3注释 ];
    字段4 字段4类型 [ comment 字段4注释 ]
    ) [comment 表注释 ];

    例:create table student (
    id int comment '编号',
    name varchar(50) comment '年龄',
    age int comment '年龄',
    gender varchar(1) comment '性别'
    ) comment '学生表';

DDL-表操作-修改

  • 添加字段

  • alter table 表名 add 字段名 类型(长度) [comment 注释] [约束];

    例:为student表增加一个新的字段"姓名"为name,类型为varchar(20)
    alter table student add name varchar(20) comment '姓名';

  • 修改数据类型(即修改指定字段的数据类型)

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

  • 修改字段名和字段类型

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

    例:将student表中的name字段改为username,类型为varchar(30)
    alter table studeng change name username varchar(30) comment '用户名';

  • 删除字段(即删除指定表中的指定字段)

  • alter table 表名 drop 字段名;

    例:将student表中的username 删除
    alter table student drop username;

  • 修改表名

  • alter table 表名 rename to 新表名;

    将student表的表明修改为students;
    alter table student rename to students;

  • 删除表

  • drop table [ if exists ] 表名;

    例:drop table students;

  • 删除指定表,并重新创建改表

  • truncate table 表名

    truncate table students;

相关推荐
程序猿20231 分钟前
MySQL的逻辑存储结构
java·数据库·mysql
2301_800256111 小时前
第九章:空间网络模型(空间网络查询、数据模型、Connected、with Recursive、pgRouting)
网络·数据库·算法·postgresql·oracle
霖霖总总2 小时前
[小技巧19]MySQL 权限管理全指南:用户、角色、授权与安全实践
数据库·mysql·安全
heartbeat..7 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
麦聪聊数据9 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
AC赳赳老秦9 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
myzshare10 小时前
实战分享:我是如何用SSM框架开发出一个完整项目的
java·mysql·spring cloud·微信小程序
YMatrix 官方技术社区10 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
辞砚技术录11 小时前
MySQL面试题——索引2nd
数据库·mysql·面试
linweidong11 小时前
C++thread pool(线程池)设计应关注哪些扩展性问题?
java·数据库·c++