【mysql】—— 数据库的操作

news2024/11/27 8:27:34

序言:

在上篇文章我已经对数据库进行了详细的介绍,接下来我们就将上手学习操作的细节了。本篇文章便带领大家去学习有关库操作的基本知识!!!

MySQL标志矢量图 - 设计之家

 

目录

(一)库的操作

1、 创建数据库

2、字符集和校验规则

1️⃣ 查看系统默认字符集以及校验规则

 2️⃣ 查看数据库支持的字符集

3️⃣ 查看数据库支持的字符集校验规则

4️⃣ 创建数据库案例

5️⃣ 校验规则对数据库的影响

(二)操纵数据库

1、查看数据库

2 、显示创建语句

 3、修改数据库

4、数据库删除 

5、查看连接情况

6、备份和恢复

1️⃣备份

2️⃣注意事项

总结


 

(一)库的操作

1、 创建数据库
 

在上篇文章中我带大家简单的看了一下数据库的创建过程,本期我们便具体展开来谈谈其中的细节。

在MySQL中,可以使用  CREATE DATABASE 语句来创建数据库。下面是创建数据库的基本语法:

  •  其中,db_name 及 database_name 是要创建的数据库的名称;
  • IF NOT EXISTS :可选参数,表示如果数据库已经存在则不执行创建操作;
  • CHARACTER SET: 指定数据库采用的字符集
  • COLLATE:  指定数据库字符集的校验规则
     

例如,要创建一个名为 "mydatabase" 的数据库,可以使用以下命令:

create database mydatabase;

 

当我们重新另起一个页面进入【/var/lib/mysql】目录下时,我们可以发现此时目录下多出了一个【mydatabase】的目录:

 此时,假设由于创建的数据库太多了,导致自己创建的数据库名字忘掉了。此时,我们可以添加一些设置操作:

【分析】 

  •  这条语句将检查数据库是否已经存在。如果数据库尚未存在,则会创建名为 "mydatabase" 的数据库;
  • 如果数据库已经存在,则不执行任何操作。很明显,上述我们床架了一个名为【mydatabase】的数据库,因此不会被重新创建

 

紧接着,当我们想删除掉这个数据库时,应该怎么做呢?此时,我们像下述这样:

  • 要删除名为 "mydatabase" 的数据库,可以使用以下命令:
drop database mydatabase;

 

 

因此,我们不难发现,在mysql 环境下创建数据库相当于在【/var/lib/mysql】增加一个文件而已。那么,我们也可以直接在【/var/lib/mysql】下创建一个文件是不是就相当于在 mysql 环境下创建一个数据库呢? 具体如下:

 结果显而易见,我们可以进行这样的操作,但是此时会有一个问题,那就是当我们我们在【/var/lib/mysql】想删除时,我们却无法进行 相关操作:

  •  而当我们在 mysql 环境下使用指令删除时,我们是可以正确的删除的:

 


2、字符集和校验规则

  • 创建名为 db1 的数据库
     
create database db1;

说明

        当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_ general_ ci

在MySQL中创建数据库时,常用的两个字符集编码:

  • 数据库编码集:数据库未来存储数据;
  • 数据库校验集:支持数据库,进行字段比较使用的编码,本质也是一种读取数据库中数据采用的编码格式;

1️⃣ 查看系统默认字符集以及校验规则
 

要查看MySQL数据库系统的默认字符集和校对规则,可以使用以下查询语句:

  • 查询结果将会返回类似下面的信息:

  •  第一条查询语句将显示与字符集相关的系统变量

  •  第二条查询语句将显示与校对规则(排序规则)相关的系统变量。

 2️⃣ 查看数据库支持的字符集

show charset;

当使用 SHOW CHARSET;命令时,MySQL会显示当前数据库中可用的字符集,并提供相关信息,例如字符集名称、默认排序规则和描述。

  • 以下是执行 SHOW CHARSET;查询的示例输出:

 

3️⃣ 查看数据库支持的字符集校验规则

show collation;

 当使用 SHOW COLLATION;命令时,MySQL将显示当前数据库中可用的校对规则(排序规则),并提供相关信息,例如校对规则名称、字符集、ID和描述。

  • 以下是执行 SHOW COLLATION; 查询的示例输出的一部分:

查询结果将列出可用的校对规则及其相关信息,如校对规则名称、字符集、ID、是否为默认校对规则(Default)、是否已编译(Compiled)以及排序长度(Sortlen)。

4️⃣ 创建数据库案例
 

💨 创建一个使用utf8字符集的 db2 数据库

create database db2 charset=utf8;
  •  显示如下:

💨 创建一个使用utf字符集,并带校对规则的 db3 数据库

create database db3 charset=utf8 collate utf8_general_ci;
  •  显示如下:

 

5️⃣ 校验规则对数据库的影响

  • 不区分大小写
     

创建一个数据库,校验规则使用 utf8_ general_ ci [不区分大小写]
 

create database test1 collate utf8_general_ci;

显示如下:

 

紧接着进入表中,在进行建表操作:

  进行查询:

 结果排序:

 

 

 

  • 区分大小写
     

创建一个数据库,校验规则使用 utf8_ bin [区分大小写]
 

create database test2 collate utf8_bin;

显示如下:

 紧接着进入表中,在进行建表操作:

 

  进行查询:

  结果排序:

 


(二)操纵数据库

1、查看数据库

show databases;

这个就不过多介绍了,在之前我们一直再用。

此外,我在给大家介绍一个新的东西:

  • SELECT DATABASE(); 是一个MySQL查询,用于获取当前正在使用的数据库的名称。

当你执行这个查询时,它将返回当前正在使用的数据库的名称作为结果。例如,如果当前正在使用的数据库是"test2",那么执行 SELECT DATABASE(); 将返回如下结果:

  •  请注意,这是一个只返回结果的查询,不会对数据库进行任何修改或操作

2 、显示创建语句
 

show create database 数据库名;

示例:

【分析】

  1. MySQL 建议我们关键字使用大写,但是不是必须的。
  2. 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  3. /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话

 3、修改数据库

语法:
 

ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]


alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

  • 对数据库的修改主要指的是修改数据库的字符集,校验规则

实例: 将 test2 数据库字符集改成 gbk
 

4、数据库删除
 

语法:

DROP DATABASE [IF EXISTS] db_ name;

示例:删除test1

 

执行删除之后的结果:

  • 数据库内部看不到对应的数据库
  • 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删
     

💨 注意:不要随意删除数据库

5、查看连接情况

语法:
 

show processlist

输出显示:

可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登陆的,很有可能你的数据库被人入侵了。以后大家发现自己数据库比较慢时,可以用这个指令来查看数据库连接情况。
 

6、备份和恢复

1️⃣备份

在MySQL中,可以使用多种方法进行数据库的备份和恢复。以下是两种常用的方法:

  • 使用 mysqldump 工具进行备份和恢复:

备份数据库:可以使用以下命令来备份整个数据库:

# mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径

例如,要备份名为"db1"的数据库,使用以下命令:

mysqldump -P3306 -u root -p123456 -B db1> db1.sql

  •  这将把整个数据库保存到名为"db1.sql"的SQL文件中。

恢复数据库:可以使用以下命令来还原数据库:

mysql -u 用户名 -p 数据库名 < 备份文件.sql

例如,要还原名为"db1"的数据库,使用以下命令:

mysql -u root -p db1< db1.sql

  1. 这将从"db1.sql"文件中读取SQL语句,并还原数据库。

  • 使用物理文件拷贝进行备份和恢复:

备份数据库:可以直接拷贝MySQL数据目录来备份数据库。首先停止MySQL服务,然后复制MySQL数据目录到备份位置即可。

恢复数据库:要恢复数据库,只需将备份的数据目录拷贝回MySQL数据目录的原始位置,并确保相应的权限和所有权设置正确。然后重新启动MySQL服务即可。

无论使用哪种方法,都建议定期备份数据库以确保数据的安全性,并根据需要进行恢复。

2️⃣注意事项

如果备份的不是整个数据库,而是其中的一张表,怎么做?
 

# mysqldump -u root -p 数据库名 表名1 表名2 > db1.sql

同时备份多个数据库
 

# mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

  • 如果备份一个数据库时,没有带上【-B】 参数, 在恢复数据库时,需要先创建空数据库,然后使用数据库,再使用source来还原

总结

到此,关于本文的内容便讲解结束了。感谢大家的观看与支持!!!

 

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

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

相关文章

创新涌动于先,PingCAP 用户峰会 2023 成功举办

2023 年 7 月 13 日&#xff0c;企业级开源分布式数据库厂商 PingCAP 在京成功举办 PingCAP 用户峰会 2023。本届峰会以“创新涌动于先”为主题&#xff0c;PingCAP 全面解析了 AI 时代 TiDB 的演进方向&#xff0c;宣布 TiDB Serverless 正式商用。会上&#xff0c;PingCAP 携…

功率信号源操作注意事项有哪些

功率信号源一种用来生成特定频率、幅度、相位和波形的电信号的设备&#xff0c;通常用于测试电子设备的性能。在使用功率信号源的过程中&#xff0c;需要注意一些安全性和操作规范。下面是一些有关功率信号源操作注意事项的详细介绍。 图&#xff1a;安泰ATG-2000系列功率信号源…

Python开源内容管理系统: Djangocms

一、Djangocms简介 Djangocms是基于Python语言开发的一款开源内容管理系统。它采用了Django框架&#xff0c;可以快速构建高效、灵活的网站。Djangocms拥有强大的可扩展性和易用性&#xff0c;支持多语言、多站点等功能。此外&#xff0c;Djangocms还提供了丰富的插件和主题&a…

JVM学习笔记(二)内存结构

目录 一、JVM内存结构 1. 虚拟机栈&#xff08;JVM Stacks&#xff09; 1&#xff09;定义 2&#xff09;栈内存溢出 3&#xff09; 线程运行诊断 案例1&#xff1a;CPU占用过高 案例2&#xff1a;程序运行很长时间没有结果​编辑 2. 本地方法栈&#xff08;Native Meth…

AlGaN基深紫外FP激光器仿真模型及材料信息数据库有何用途?

波长范围为UVC波段&#xff08;100-280 nm&#xff09;的深紫外FP&#xff08;Fabry-Pero&#xff0c;法布里和珀罗是两位法国的科学家&#xff09;激光器可广泛应用于数据通信、光通信、3D打印、材料加工、显示与照明、激光雷达、人脸/手势识别、医疗和表面监测等领域。FP激光…

Ubuntu 更改内核启动顺序

ubuntu服务器系统中用run包安装了某卡的驱动&#xff0c;后来又安装了docker&#xff0c;重启后&#xff0c;驱动失效。 经分析 安装docker时&#xff0c;又把新的linux内核安装上了。驱动是安装在旧内核上。 然会重新安装驱动&#xff0c;失败&#xff0c;确认是因为驱动只支…

最短路计数

题意&#xff1a;求1号点到每个点的最短路径的条数 分析&#xff1a;模板题&#xff0c;但要保证求的顺序是拓扑序&#xff0c;如果遇到的点的距离大于当前被更新点的距离就覆盖这个点之前的数据&#xff08;比如如果先通过3-->2-->4,后来发现了另一条路3-->4&#x…

软件设计师(一)计算机系统知识

一、计算机系统基础知识 1、计算机系统硬件基本组成 基本硬件系统由运算器、控制器、存储器、输入设备和输出设备5大部件组成。 组成说明运算器、控制器集成在一起统称为中央处理单元&#xff08;CPU&#xff09;。CPU是硬件系统的核心&#xff0c;用于数据的加工处理存储器…

企业数字化的本质是什么?企业数字化建设应该怎么做?

近年前&#xff0c;无论哪个领域数字化都成为一种必选项&#xff0c;任何行业都可以用数字化的手段重新做一遍&#xff0c;但其本质含义就是基于一种数字化手段、数字化的工具再造企业&#xff0c;用新的数字化的思维手段来重新赋能业务。 企业数字化本质是技术与体系的联合&a…

IP-GUARD授权库勾选“不跟踪另存为”的效果

容灾时间过期如何申请延长? 有以下几种方式可以在已经超过容灾时间后,让客户端正常使用加密: 1、直接从控制台设置好容灾时间或者长期离线授权,右键客户端导出策略,然后从客户端c:\windows,调出policyimporttool.exe,导入策略即可。 2、直接在控制台设置好长期离线授权…

F#奇妙游(12):并行编程与π

核越多&#xff0c;越快乐 多核CPU对于计算机程序的开发带来了很大的挑战&#xff0c;但是也带来了很大的机遇。在多核CPU上&#xff0c;程序的性能可以通过并行化来提升&#xff0c;但是并行化的难度也随之提升。本文将介绍多核CPU的基本概念&#xff0c;以及如何在多核CPU上…

【分布式任务调度】XXL-JOB调度中心对执行器的上下线感知实现原理(三)

文章目录 1. 前言2. 调度关系3. 执行器注册3.1. 调度中心处理注册请求3.2. 执行器发起注册请求 4. 执行器注销4.1.主动注销4.2. 被动注销 5.流程图6. 总结 1. 前言 XXL-JOB专题历史文章列表&#xff1a; XXL-JOB调度中心集群部署配置&#xff08;一&#xff09;XXL-JOB执行器…

官宣!Databend Cloud 和青云科技达成合作

近日&#xff0c;北京数变科技有限公司与北京青云科技股份有限公司(以下简称&#xff1a;青云科技 &#xff09;顺利完成了产品兼容性适配互认证。本次测试是对 Databend 云原生数据仓库系统与青云科技公司自主研发的 QingStor U10000 进行严格的联合测试验证。测试结果显示&am…

数字 IC 设计职位经典笔/面试题(二)

共100道经典笔试、面试题目&#xff08;文末可全领&#xff09; FPGA 中可以综合实现为 RAM/ROM/CAM 的三种资源及其注意事项&#xff1f; 三种资源&#xff1a;BLOCK RAM&#xff0c;触发器&#xff08;FF&#xff09;&#xff0c;查找表&#xff08;LUT&#xff09;&#xf…

CAS机制详解

一、是什么 CAS&#xff0c;是Compare and Swap的简称&#xff0c;实现并发算法是常用到的一种技术&#xff0c;在这个机制中有三个核心的参数。 主内存中存放的共享变量的值&#xff1a;V&#xff08;一般情况下这个V是内存的地址值&#xff0c;通过这个地址可以获得内存中的…

mysql数值函数

1. ceil() 向上取整 2. floor() 向下取整 3. mod() 取余 4. rand() 生成0-1之间的随机数 5. round(x&#xff0c;y) x 四舍五入&#xff0c;保留 y 位小数

【Spring core学习三】对象装配:获取Bean对象的四种方式

目录 对象装配的四种方式 &#x1f337;1、Autowired属性注入&#xff08;使用最多&#xff09; &#x1f337;2、Setter注入 &#x1f337;3、构造函数注入 &#x1f337;4、Resource&#xff1a;另⼀种注⼊关键字 对象装配的四种方式 对象装配&#xff1a;获取bean对象也…

2、用phpMyAdmin修改mysql的密码

用phpMyAdmin登录mysql服务器&#xff0c;默认的用户名密码为 Username: root Password: [null] 在账户中修改密码

8.分布式存储

文章目录 分布式存储存储基础单机存储设备单机存储的问题分布式存储&#xff08;软件定义的存储 SDS&#xff09;分布式存储的数据类型总结 CephCeph概念Ceph优势Ceph架构Ceph核心组件OSD 存储后端Ceph 数据的存储过程Ceph 版本发行生命周期Ceph 集群部署Ceph 生产环境推荐&…

虚拟机磁盘扩容

工作中已经不止一次碰到虚机扩容了&#xff0c;所以一定要切记&#xff1a;给虚机多分配些容量&#xff01;&#xff01; 方法其实就是现在物理机上给磁盘扩容&#xff0c;然后再跑到虚拟机内部进行lvm卷扩容&#xff0c;具体的原理到去看LVM底层&#xff0c;总体就是LV->V…