当前位置: 首页 > news >正文

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;
http://www.lryc.cn/news/612673.html

相关文章:

  • 直连微软,下载速度达18M/S
  • [2402MT-A] Redbag
  • 从周末去哪儿玩到决策树:机器学习算法的生活启示
  • 《深入解析缓存三大难题:穿透、雪崩、击穿及应对之道》
  • Mysql数据仓库备份脚本
  • 突破距离桎梏:5G 高清视频终端如何延伸无人机图传边界
  • 【完整源码+数据集+部署教程】无人机自然场景分割系统源码和数据集:改进yolo11-RVB
  • 计算机网络1-4:计算机网络的定义和分类
  • 【网络编程】一请求一线程
  • 云原生安全挑战与治理策略:从架构思维到落地实践
  • PyTorch + PaddlePaddle 语音识别
  • 从BaseMapper到LambdaWrapper:MyBatis-Plus的封神之路
  • day44 力扣1143.最长公共子序列 力扣1035.不相交的线 力扣53. 最大子序和 力扣392.判断子序列
  • WEB开发-第二十七天(PHP篇)
  • 笔试——Day31
  • Linux(17)——Linux进程信号(下)
  • 【42】【OpenCV C++】 计算图像某一列像素方差 或 某一行像素的方差;
  • uniapp vue3中使用pinia 和 pinia持久化(没有使用ts)
  • SQLite 创建表
  • VUE+SPRINGBOOT从0-1打造前后端-前后台系统-文章列表
  • [失败记录] 使用HBuilderX创建的uniapp vue3项目添加tailwindcss3的完整过程
  • 《深入浅出 Django ORM:设计理念与惰性查询实现详解》
  • Django 表单:深度解析与最佳实践
  • 上门家教 app 用户端系统模块设计
  • 解锁高效开发:AWS 前端 Web 与移动应用解决方案详解
  • 深度解析:打造一个文件、可持续的Python网络爬虫——以澳洲房地产网站为例
  • uni-app vue3 小程序接入 aliyun-rtc-wx-sdk
  • 深拷贝之 structuredClone ()
  • JavaSE---异常的经典面试题
  • SUNO音乐歌曲生成平台的关键字指令