【MySQL】数据库基础(库的操作)

目录

一、MySQL安装、连接、修改密码操作

二、库的操作

2.1 创建数据库

2.2 字符集和校验规则

2.3 操控数据库

2.4 修改数据库

2.5 删除数据库

2.6 数据库的备份和恢复

2.7 查看连接情况


前情提要:

我的服务器操作系统是Ubuntu20.04,安装的是MySQL8.0版本。

一、MySQL安装、连接、修改密码操作

参考了这篇博客:【究极详细版】Ubuntu安装配置MySQL_ubuntu配置mysql-CSDN博客

二、库的操作

MySQL编写SQL语句时默认是不区分大小写的。(表名、列名、别名等标识符是否区分大小写取决于服务器操作系统的文件系统以及MySQL的配置设置,Linux系统是区分大小写的)

2.1 创建数据库

语法:

CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,
create_specification] ...]create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

  • 大写的表示关键字
  • [ ] 是可选项,使用可选项时不用加上方括号
  • create_specification:是在创建数据库时可以指定的额外选项或规范,用于定义数据库的字符集、校对规则等属性。
  • CHARACTER SET: 指定数据库采用的字符集
  • COLLATE: 指定数据库字符集的校验规则(编码集)

例如:

CREATE DATABASE mytest
CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;

说明:创建一个名为mytest的数据库,并指定字符集为utf8mb4(这是MySQL 5.5.3及以上版本推荐使用的字符集,因为它支持存储任何Unicode字符,包括表情符号)以及默认的校对规则utf8mb4_unicode_ci。这些选项确保了新创建的数据库使用utf8mb4字符集和相应的utf8mb4_unicode_ci校对规则。

补充:

  1. 在MySQL中创建库,本质是在Linux下建立目录,一个目录对应一个库。
  2. 但不是仅仅创建一个库,还会包含存储数据库的相关文件。
  3. 所以要删除数据库或者添加数据库时,不要对底层的目录进行修改,而是在MySQL中使用SQL语句完成。

2.2 字符集和校验规则

字符集:字符集定义了数据库中可以存储的字符集以及每个字符的编码方式。

数据库编码集:是字符集的具体实现,用于确保数据以正确的格式存储在数据库中。

以下是一些常见的字符集:

  • latin1:西欧语言,ISO 8859-1字符集。
  • utf8:Unicode字符集,最多支持每个字符3字节。
  • utf8mb4:扩展的Unicode字符集,最多支持每个字符4字节,可以存储任何Unicode字符,包括emoji。

校验规则:定义了字符集中字符的比较规则,包括字符的排序顺序和比较时的区分度(例如是否区分大小写、重音等)。(字符集通常与校验规则搭配使用。因为同一个字符集可以有不同的校验规则。)

查看系统默认字符集以及校验规则:

show variables like 'character_set_database';
show variables like 'collation_database';

查看数据库支持的字符集:

show charset;

查看数据库支持的字符集校验规则:

show collation;

校验规则对数据库的影响:

1. 不区分大小写:

  • 当校验规则不区分大小写时,例如utf8_general_ci,查询和排序时不会区分字母的大小写。
  • 即使表中存在大小写不同的同义词,查询也会将它们视为相同的值。
  • 例如,查询SELECT * FROM users WHERE username = 'John'会匹配到john、JOHN和John等所有大小写形式。

2. 区分大小写:

  • 当校验规则区分大小写时,例如utf8_bin,查询和排序时会严格区分字母的大小写。
  • 表中的同义词必须完全匹配查询条件的大小写格式。
  • 例如,查询SELECT * FROM users WHERE username = 'John'只会匹配到John,而不会匹配到john或JOHN。

3. 进行查询:

  • 校验规则会影响查询的性能,因为不区分大小写的校验规则在比较时可能会进行额外的转换,从而影响查询速度。
  • 区分大小写的校验规则在比较时更快,因为它们直接比较字符的二进制表示。

4. 结果排序:

  • 校验规则决定了排序的顺序,包括字母、数字和特殊字符的顺序。
  • 例如,utf8_unicode_ci校验规则会根据Unicode标准来排序字符,这可能与常规的ASCII排序不同。
  • 区分大小写的校验规则在排序时会根据大小写规则来排列字符,而不会将大小写视为相同。

2.3 操控数据库

查看数据库

show databases;

显示创建语句

show create database 数据库名;

说明:

  • MySQL 建议我们关键字使用大写,但是不是必须的。
  • 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  • /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话 
  • \G 是一个转义序列,用于指定输出格式。使用\G时,MySQL会将查询结果以垂直格式输出,而不是默认的水平格式。这种格式使得查询结果更容易阅读,尤其是在结果比较长时。而且会去掉一些不必要的字符。

2.4 修改数据库

语法:

ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

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

例如: 将 mytest 数据库字符集改成 gbk :alter database mytest charset=gbk;

2.5 删除数据库

DROP DATABASE [IF EXISTS] db_ name;

执行删除之后的结果:

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

注意:不要随意删除数据库,这是因为MySQL的删除操作是物理删除,一旦删除,数据将无法恢复。因此比较建议删除前考虑创建一个数据库的备份,以防止错误删除。

2.6 数据库的备份和恢复

备份(在bash中执行):

语法:

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

示例:将mytest库备份到文件(退出连接)

mysqldump -P3306 -u root -p123456 -B mytest > /MySQL/mytest.sql

这时,可以打开看看 mytest.sql 文件里的内容,其实把我们整个创建数据库,建表,导入数据的语句都装载这个文件中。

  • 上面的命令都是退出MySQL,在Linux命令行中输入的。
  • 路径中的MySQL是自定义创建的文件夹,用来保存备份文件。
  • mysqldump:这是一个MySQL客户端工具,用于将数据库的结构和数据导出为SQL语句。
  • -P3306:指定MySQL服务器的端口号。MySQL的默认端口号是3306,但有时服务器管理员会更改它。
  • -u root:指定MySQL服务器的用户名。root是MySQL的超级用户,拥有最高权限。
  • -p 密码:指定MySQL服务器的密码。密码需要用单引号括起来,如果密码中包含空格或特殊字符,需要用单引号括起来。
  • -B mytest:指定要备份的数据库名。mytest是您想要备份的数据库的名称。
  • > /MySQL/mytest.sql:将导出的SQL语句输出到文件。/MySQL/mytest.sql是你指定保存备份文件的路径和文件名。

如果备份的不是整个数据库,而是其中的一张表:

mysqldump -u root -p 数据库名 表名1 表名2 > 数据库所要存储的文件路径
同时备份多个数据库
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库备份存储的文件路径

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

还原(在MySQL中执行):

source 备份库所在的完整路径;

2.7 查看连接情况

语法:

show processlist;

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

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

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

相关文章

关于Spring Boot的自动配置

目录 1.EnableAutoConfiguration注解 2.SpringBootConfiguration注解 3.Import注解 4.spring.factories 5.总结 (1)EnableAutoConfiguration (2)AutoConfigurationImportSelector (3) SpringFactoriesLoade…

【好书推荐】值得深读的EMC参考书籍

以下排序不分先后,都是好书! 书名:Electromagnetic Compatibility Engineering 作者:Henry W. Ott 这本书的讨论重点放在了经济高效的EMC设计上,并将数学的数量和复杂度保持在最低限度,辅以 250 多个带有…

Jenkins汉化配置详解

Window安装构建神器Jenkins Window安装构建神器Jenkins详细教程-CSDN博客DevOps,CI,CD,自动化简单介绍选择其他需要和Jenkins一起安装的服务,点击Next。https://blog.csdn.net/qq_37237487/article/details/141299623 登录进入J…

什么是BOM,有哪些分类?

一、什么是BOM? BOM是物料清单的缩写,也称为产品结构表或产品结构树。 BOM的作用主要是通过计算机辅助企业生产管理,使计算机能够识别企业所制造的产品构成和所有要涉及的物料。 在制造业中,BOM是一份详细记录制造某个产品时所…

大模型19:微调大模型方法

有监督微调(SFT)、奖励模型(RM)训练,以及基于人类反馈的强化学习(RLHF)训练 1. 有监督微调(SFT - Supervised Fine-Tuning) 数据处理 数据收集:首先&#x…

cdr工具介绍之刻刀工具

在日常的生活当中,在很多时候我们会遇到各种各样的难题,但软件cdr他就是一个神奇的存在,因为他能帮助我们解决很多专业方面的的知识。尽管他的内容相比较其他的一些设计软件而言相对于较为少,但是他确实一个非常适合于平常的工作学…

[Linux CMD] 查询占用进程 fuser

常用 fuser -n file xxx.sh #查找占用进程 kill Process_ID 基本语法 fuser [选项] 文件/目录/套接字 常用选项 -n:指定命名空间,可以是 file (默认)、inet (网络连接)、udp (UDP 连接) 或 unix (Unix 套接字)。例如,-n file 表示后面跟…

在 uboot 中实现 UDP 协议

一、明确背景 uboot中有许多通信协议,像TFTP、NFS等,这些协议底层都是基于UDP协议来实现的,由于有一个板子在 uboot 段进行固件下载更新的需求,本来想基于TCP协议来实现自定义通信协议(TCP有自带的拥塞控制和重传机制&…

【人工智能】TensorFlow lite介绍、应用场景以及项目实践:使用TensorFlow Lite进行数字分类

一、TensorFlow Lite 介绍 TensorFlow Lite(简称TFLite)是谷歌开发的一种轻量级的深度学习框架,专为移动设备和嵌入式设备设计。它是TensorFlow的移动和嵌入式设备版本,旨在帮助开发者在资源受限的设备上执行机器学习模型。Tenso…

vue生命周期函数

文章目录 1.vue21.1 Vue 生命周期 和 生命周期的四个阶段1.2 Vue 生命周期函数(钩子函数) 2.vue3 1.vue2 1.1 Vue 生命周期 和 生命周期的四个阶段 (1)create指的是数据代理和数据监测的创建 1.2 Vue 生命周期函数(钩…

docker手动部署django项目Dockerfile编排-后端发布

1、首先创建一个桥接网络 docker network create auto 2、部署redis,提供celery的消息队列服务 docker run --name redis --restartalways -d --network auto -v redis:/data redis:alpine3、部署数据库 注意数据库账号密码 docker run --name mariadb --restartalways -d…

九泰智库 | 医械周刊- Vol.51

⚖️ 法规动态 白内障人工晶体类医用耗材集采落地,平均降幅60% 湖北省自7月10日起实施人工晶体类医用耗材集中带量采购政策,中选产品平均降幅达60%,显著减轻了患者经济负担。此举是国家组织医用耗材采购的一部分,旨在通过集中采购…

python-leetcode刷题日记

1、defaultdict 用于计数,计算元素key出现的个数,可以避免key不存在的时候报错,当KEY不存在的时候默认为0,可以是list、set、str defaultdict[key].append[value] 49. 字母异位词分组 ​ 给你一个字符串数组,请你将 字母异位词…

Eureka Server与Eureka Client详解:服务注册与发现的交互机制

Eureka Server与Eureka Client详解:服务注册与发现的交互机制 Eureka 是 Netflix 开源的一个服务发现框架,它是 Spring Cloud 微服务架构中的核心组件之一。Eureka 主要由两个关键组件构成:Eureka Server 和 Eureka Client。它们之间通过一定…

完美解决html2canvas + jsPDF导出pdf分页内容截断问题

代码地址:https://github.com/HFQ12333/export-pdf.git html2canvas jspdf方案是前端实现页面打印的一种常用方案,但是在实践过程中,遇到的最大问题就是分页截断的问题:当页面元素超过一页A4纸的时候,连续的页面就会…

v4l2(video4linux2) yuyv(yuv422)、MJPEG、H.264

V4L2(Video4Linux2)是Linux内核中的视频设备接口框架,专门用于捕获和输出视频数据。V4L2广泛应用于各种视频设备的驱动程序开发,如网络摄像头、电视调谐器、视频采集卡、以及其他视频输入/输出设备。 ### V4L2的主要功能 1. **视…

c++ 谷歌的招聘 题解

题目描述 2004 年 7 月,谷歌在硅谷的 101 号公路边竖立了一块巨大的广告牌(如下图)用于招聘 内容超级简单,就是一个以 .com 结尾的网址,而前面的网址是一个 10 位素数,这个素数是自然常数 e 中最早出现的 10 位连续数字 能找出这个素数的人,就可以通过访问谷歌的这个网站进入…

CSS”叠叠乐“——WEB开发系列16

在现代前端开发中,CSS 是控制网页外观和布局的核心工具。随着项目的复杂化和样式规则的增加,CSS 层叠(cascade)变得更加重要。为了更好地管理和控制样式规则的应用,CSS 引入了层叠层(cascade layers&#x…

linux centos 防火墙常用命令

1、开放端口 firewall-cmd --zonepublic --add-port80/tcp --permanent 1 2、查看某端口是否开放 firewall-cmd --query-port80/tcp 1 3、查看端口开启列表 firewall-cmd --list-port 1 4、重启防火墙 firewall-cmd --reload 1 5、关闭防火墙 systemctl stop firewalld.se…

Java—Lambda表达式

注意:如果无法判断一个方法是否为函数式接口,可以查看该方法的源码中是否携带FunctionalInterface注解。 lambda表达式再简化写法规则如下。 1. 参数类型可以省略不写 2. 如果只有一个参数,参数的 "( )" 也可以省略。 3. 如果Lambd…