数据库mysql-对数据库和表的DDL命令

news2024/9/21 20:44:23

文章目录

  • 一、什么是DDL操作
  • 二、数据库编码集和数据库校验集
  • 三、使用步骤
    • 对数据库的增删查改
      • 1.创建数据库
      • 2.进入数据库
      • 3.显示数据库
      • 4.修改数据库
        • mysqldump
      • 5.删除数据库
    • 对表的增删查改
      • 1.添加/创建表
      • 2.插入表内容
      • 3.查看表
        • 查看所有表
        • 查看表结构
        • 查看表内容
      • 4.修改表
        • 修改表的名字
        • 修改表的结构
          • 对表结构的增加
          • 对表结构的其中一列属性进行修改
          • 对表结构的其中一列改名并修改属性
          • 对表结构的删除
        • 删除表


一、什么是DDL操作

DDL(Data Definition Language),是数据定义语言的缩写,它是SQL(Structured Query Language)语言的一个子集,用于定义或修改数据库的结构。DDL主要包括创建(CREATE)、修改(ALTER)、删除(DROP)等操作。

二、数据库编码集和数据库校验集

数据库编码集就是当对数据库内容进行存储时,采用怎样的编码格式来存储。
数据库校验集就是当对数据库内容进行读取时,采用怎样的编码格式来读取。

所以,为了保证数据库在读取数据时,不会产生乱码,我们就需要让数据库的编码集和校验集进行对应,比如说用utf8的格式进行存储,那么也必须使用utf8的格式进行读取!

如何查看自己的mysql支持怎样的编码集和校验集?
show charset; 查看编码集
show collation; 查看校验集

如何查看当前的默认的编码集和校验集?
show variables like 'character_set_database';
show variables like 'collation_database';
在这里插入图片描述

三、使用步骤

对数据库的增删查改

1.创建数据库

现在我要创建一个名为test的数据库,应该怎么创建呢?

  1. create database test; 这是最简单的写法。
  2. create database if not exists test; 加上if not exists 表示如果不存在该数据库才创建。
  3. create database if not exists test charset=utf8mb3 collate=utf8mb3_general_ci; 加上charset=utf8mb3,让该数据库默认采用utf8mb3的编码集格式,collate=utf8mb3_general_ci让该数据库默认采用utf8mb3_general_ci的编码集格式。这里的charset=utf8mb3还可以写成 character set utf8mb3;collate=utf8mb3_general_ci还可以写成collate utf8mb3_general_ci。

当我们创建一个数据库之后,我们可以在/var/lib/mysql路径下找到对应的数据库目录。

2.进入数据库

use database_name;
在这里插入图片描述
进入了这个数据库,我们才能再对数据库中的表进行增删查改。

3.显示数据库

show databases;
在这里插入图片描述
如何查看我当前所在的数据库?
select database();
在这里插入图片描述

4.修改数据库

对数据库进行修改只能修改其字符编码集和字符校验集。
alter database test charset=gbk collate=gbk_chinese_ci;
在这里插入图片描述
SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME
FROM information_schema.SCHEMATA
WHERE SCHEMA_NAME = DATABASE();

那有没有修改数据库名字的操作呢? 以前有,但是被移除了,因为不安全!
如果想要修改数据库的名字,应该使用mysqldump进行备份!

首先这里需要插入一个前备知识。
当输入show create database test;
在这里插入图片描述
需要注意的是,这里的/*!40100 DEFAULT CHARACTER SET gbk / /!80016 DEFAULT ENCRYPTION=‘N’ */并不是注释,而是可变选项!

所以这个指令是什么意思? 这个指令是告诉我们如果要创建一个test数据库,需要输入怎样的指令。


mysqldump

mysqldump是一个bash命令,并不是mysql命令,这个命令程序在安装mysql的时候也顺带安装上了。
我们如果要将某个数据库进行备份,就可以使用这个命令。

我们先在test库先创建一个表,并插入一些内容以便等会看实验现象。

在这里插入图片描述

此时我们再退出数据库,并进入一个空目录下,执行命令
mysqldump -P 3306 -u root -p -B test >./test.sql
再使用ls就可看到,此目录多出一个test.sql的文件。
我们可以打开文件,看文件的内容是什么。
在这里插入图片描述

如果细心观察就可以看出这就是一串创建数据库、创建表并插入数据的mysql指令。
所以,mysqldump的备份其实是备份“指令”。

那么怎么导入这个文件为我们创建数据库呢?
再登录我们的mysql,将我们的test数据库删掉。
输入source /home/fengjunziya/test/lesson37_mysqltest/test.sql;
在这里插入图片描述
它就为我们执行了那个文件的命令,也就达到了备份导入的作用。

可是怎么修改数据库名字呢?
首先在使用mysqldump命令时不能加上-B
mysqldump -P3306 -uroot -p test > test.sql
在这里插入图片描述
这时我们就可以看到文件内的并没有创建数据库的指令。
所以我们在使用source导入的时候,就需要先创建一个数据库(新名字)再进行导入。

create database hello; 创建hello数据库
use hello; 进入hello数据库
source /home/fengjunziya/test/lesson37_mysqltest/test.sql; 导入文件指令
select database(); 查看当前所在数据库
select * from user; 查看user表中的数据内容
在这里插入图片描述
最后也是被拷贝进来了。

5.删除数据库

删除数据库很简单,但是一旦删除数据库,该数据库内的数据将全部被清空,所以需要谨慎!

drop database database_name;

需要注意的是,对于数据库而言,不论是修改还是删除,都是有风险的行为,因为我们的数据库一般都是直接与上层服务连接,一旦修改数据库的名字,或者删除数据库都可能会造成上层服务出现问题!


对表的增删查改

1.添加/创建表

创建表的格式怎么写呢?
create table table_name(...);
1.
还可以加入 if not exists
在这里插入图片描述
还可以加入comment 添加描述
在这里插入图片描述
再复杂点还可以指定字符编码集、字符校验集还有存储引擎
在这里插入图片描述

2.插入表内容

insert into table_name values (...), (...), ... ;
在这里插入图片描述
insert是下一章的DML操作,这里大家先接触一下。

3.查看表

查看所有表

show tables;
在这里插入图片描述

查看表结构

desc table_name;
在这里插入图片描述

在这里插入图片描述

查看表内容

select * from table_name;
在这里插入图片描述
select也是下一章的DML命令。

4.修改表

修改表的名字

alter table table_name rename (to) new_name;
在这里插入图片描述

修改表的结构
对表结构的增加

如果要对表原有的结构再加一栏。
alter table table_name add newfield type;

在这里插入图片描述
alter table teachers add birthday varchar(20) after gender; after gender代表是在gender后面加一栏。

对表结构的其中一列属性进行修改

alter table table_name modify field_name type;
在这里插入图片描述

对表结构的其中一列改名并修改属性

alter table table_name change field_name newfield_name type;

在这里插入图片描述

对表结构的删除

alter table table_name drop field_name;
在这里插入图片描述

删除表

drop table table_name;
在这里插入图片描述
一旦删除表,该表的数据将全部被清空,所以需要谨慎!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1923159.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

经典关系抽取(一)CasRel(层叠式指针标注)在DuIE2.0数据集上的应用

经典关系抽取(一)CasRel(层叠式指针标注)在DuIE2.0数据集上的应用 关系抽取(Relation Extraction)就是从一段文本中抽取出(主体,关系,客体)这样的三元组,用英文表示是 (subject, relation, obj…

【Windows】硬链接和软链接(OneDrive同步指定目录?)

文章目录 一、场景带入二、Windows下的硬链接和软链接2.1 硬链接(Hard Link)2.2 软链接(符号链接,Symbolic Link)2.3 软链接和快捷方式2.4 应用场景 三、OneDrive中的应用3.1 错误姿势3.2 好像可行的尝试3.3 合理的解决…

SpringBoot使用Redisson操作Redis及使用场景实战

前言 在SpringBoot使用RedisTemplate、StringRedisTemplate操作Redis中,我们介绍了RedisTemplate以及如何SpringBoot如何通过RedisTemplate、StringRedisTemplate操作Redis。 RedisTemplate的好处就是基于SpringBoot自动装配的原理,使得整合redis时比较…

51单片机(STC8H8K64U/STC8051U34K64)_RA8889_8080参考代码(v1.3)

硬件:STC8H8K64U/STC8051U34K64 RA8889开发板 硬件跳线变更为并口8080模式,PS00x,R143,R142不接,R141无关 8080接口电路连接图: 实物连接图: RA8889开发板外接MCU连接器之引脚定义&…

防火巡查记录卡数字化平台

防火巡查记录卡数字化平台 利用凡尔码搭建防火巡查记录卡数字化平台是一个高效且实用的解决方案,能够显著提升防火巡查的效率和管理水平。替代纸质巡检造成的数据丢失等困扰。 一、如何注册凡尔码平台 百度搜索“凡尔码”找到平台地址即可注册开通。凡尔码平台通…

二叉树层序遍历?秒了!

废话不多说,直接上题,涉及到二叉树层序遍历的题目大部分都可以用这个方法: 示例:力扣102 二叉树的层序遍历 给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有…

实验8 视图创建与管理实验

一、实验目的 理解视图的概念。掌握创建、更改、删除视图的方法。掌握使用视图来访问数据的方法。 二、实验内容 在job数据库中,有聘任人员信息表:Work_lnfo表,其表结构如下表所示: 其中表中练习数据如下: 1.‘张明…

数据结构之单链表(赋源码)

数据结构之单链表 线性表 线性表的顺序存储结构,有着较大的缺陷 插入和删除操作需要移动大量元素。会耗费很多时间增容需要申请空间,拷贝数据,释放旧空间。会有不小的消耗即使是使用合理的增容策略,实际上还会浪费许多用不上的…

【Oracle】实验五 PL_SQL编程

【实验目的】 熟悉PL/SQL的数据类型和书写规则熟悉控制结构和游标的使用编写和运行函数、过程和触发器 【实验内容】 编写脚本文件,调试运行脚本文件,并记录结果。 本地子程序的编写及调试 1、编写一个PL/SQL块,功能用于打印学生信息。整…

【学习css1】flex布局-页面footer部分保持在网页底部

中间内容高度不够屏幕高度撑不开的页面时候&#xff0c;页面footer部分都能保持在网页页脚&#xff08;最底部&#xff09;的方法 1、首先上图看显示效果 2、奉上源码 2.1、html部分 <body><header>头部</header><main>主区域</main><foot…

深入解析香橙派 AIpro开发板:功能、性能与应用场景全面测评

文章目录 引言香橙派AIpro开发板介绍到手第一感觉开发板正面开发板背面 性能性能概况性能体验 应用场景移植操作系统香橙派 AIpro开发板支持哪些操作系统&#xff1f;烧写操作系统到SD卡中启动开发板的步骤查看系统提供的事例程序体验——开发的简洁性 视频播放展示ffmpeg简介f…

【Python3】自动化测试_用Playwright发送API请求

一、创建APIRequestContex实例 # 连接到 APIRequest&#xff0c;可用于 Web API 测试的 API。 myRequest myPlaywright.request# 创建APIRequestContext实例&#xff0c;该实例可用于发送 Web 请求 myRequestContext myRequest.new_context() myRequest.new_context(**kwargs…

【MySQL】8.复合查询

复合查询 一.基本查询回顾(新增子查询)二.多表查询三.自连接四.子查询1.单列单行子查询2.单列多行子查询——三个关键字3.多列子查询4.在 from 子句中使用子查询 五.合并查询六.总结 一.基本查询回顾(新增子查询) //1.查询工资高于500或岗位为MANAGER的雇员&#xff0c;同时还…

js逆向-webpack-python

网站&#xff08;base64&#xff09;&#xff1a;aHR0cHM6Ly93d3cuY29pbmdsYXNzLmNvbS96aA 案例响应解密爬取&#xff08;webpack&#xff09; 1、找到目标url 2、进行入口定位&#xff08;此案例使用 ‘decrypt(’ 关键字搜索 &#xff09; 3、找到位置进行分析 --t 为 dat…

【软件工具】VMware Workstation Pro 15.5安装

1、双击运行安装包程序 2、接受许可证协议 3、选择安装位置&#xff0c;建议非中文无空格&#xff0c;增强型键盘驱动程序可选 4、按照自身使用习惯勾选产品更新和客户体验提升计划 5、快捷方式 6、开始安装 7、稍等会儿(可以玩会儿手机) 8、可输入许可证也可直接完成&#xff…

《ElementUI/Plus 基础知识》el-tree 之修改可拖拽节点的高亮背景和线

前言 收到需求&#xff0c;PM 觉得可拖拽节点的高亮背景和线样式不明显&#xff01;CSS 样式得改&#xff01; 注意&#xff1a;下述方式适用于ElementUI el-tree 和 ElementPlus el-tree&#xff01; 修改 拖拽被叠加节点的背景色和文字 关键类名 is-drop-inner .el-tree…

几何距离与函数距离:解锁数据空间中的奥秘

几何距离&#xff1a;直观的空间度量 几何距离&#xff0c;顾名思义&#xff0c;是我们在几何学中熟悉的距离概念&#xff0c;如欧几里得距离、曼哈顿距离和切比雪夫距离等。这些距离度量直接反映了数据点在多维空间中的位置关系。 欧几里得距离&#xff1a;最为人熟知的几何距…

conda install问题记录

最近想用代码处理sar数据&#xff0c;解放双手。 看重了isce这个处理平台&#xff0c;在安装包的时候遇到了一些问题。 这一步持续了非常久&#xff0c;然后我就果断ctrlc了 后面再次进行尝试&#xff0c;出现一大串报错&#xff0c;不知道是不是依赖项的问题 后面看到说mam…

langchain-runnable底层原理

文章目录 langchainlangchain生态介绍langchainLCELrunnablerunnable基础能力介绍invokebatchstreamainvokeabatchastream__or__、__ror__pipeget_nameInputType (属性)OutputType (属性)input_schema (属性)output_schema (属性) langchain langchain生态介绍 langchain是一个…

Min P Sampling: Balancing Creativity and Coherence at High Temperature阅读笔记

上一篇文章是关于大语言模型的调参数&#xff0c;写了temperature这个参数近期的一个工作。那接下来&#xff0c;就不得不再来讲讲top-p这个参数啦。首先还是上文章&#xff0c;同样是非常新的一个工作&#xff0c;2024年7月1日submit的呢。 文章链接&#xff1a;https://arxi…