【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,一经查实,立即删除!

相关文章

【好书推荐】值得深读的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是一份详细记录制造某个产品时所…

cdr工具介绍之刻刀工具

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

在 uboot 中实现 UDP 协议

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

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%,显著减轻了患者经济负担。此举是国家组织医用耗材采购的一部分,旨在通过集中采购…

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

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

c++ 谷歌的招聘 题解

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

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

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

Java—Lambda表达式

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

【PyTorch】神经网络的基本骨架-nn.Module的使用以及convolution-layers卷积层介绍

前提文章目录 【PyTorch】深度学习PyTorch环境配置及安装【详细清晰】 【PyTorch】深度学习PyTorch加载数据 【PyTorch】关于Tensorboard的简单使用 【PyTorch】关于Transforms的简单使用 【PyTorch】关于torchvision中的数据集以及dataloader的使用 文章目录 前提文章目录nn.…

AI编程工具的力量:以AWS Toolkit与百度Comate为例,加速程序员开发效率

在当今的数字化转型浪潮中,人工智能(AI)技术不仅重塑了众多行业,也为软件开发领域带来了革命性的变化。AI编程工具,凭借其智能化的特性,正在成为程序员提高开发效率、优化代码质量和加速产品迭代的重要助力…

SQL注入(原理、分类、union、POST注入)

目录 【学习目标、重难点知识】 【学习目标】 【重难点知识】 SQL注入简介 SQL注入原理 SQL注入类型 MySQL与SQL注入的相关知识 information_schema 数据库的结构 数据库查询语句 limit的用法 需要记住的几个函数 注释符号 SQL注入探测方法 SQL注入漏洞攻击流程…

以简单的例子从头开始建spring boot web多模块项目(五)-thymeleaf引擎

继续向里面加,这次是引入thymeleaf渲染引擎。 使用这个引擎的很多,主要是以下几个优点: Thymeleaf是适用于Web和独立环境的现代服务器端Java模板引擎。Thymeleaf的主要目标是为您的开发工作流程带来优雅的自然模板 -HTML可以在浏览器中正确显…

七牛云 CDN 视频瘦身,为视频分发「减负增效」

随着智能设备的普及,以及各种以分享视频为主的平台的兴起,人们记录生活、分享故事的方式不再局限于文字和图片,而是越来越多地通过视频来表达。视频也不再需要复杂的制作过程,变得随手可得。 然而,视频在互联网上的爆炸…

65 华为交换机CE6800基础配置

一 IPV6 使能配置思路 1 改华为交换机的名字 <huaweice65>sys Enter system view, return user view with return command. [~huaweice65]sysname HWCE6800 [*huaweice65]quit Warning: Uncommitted configurations found. Are you sure to commit them before exiting?…

抖音集团 FlinkSQL 性能优化探索及实践

本文作者&#xff1a;李精卫 更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 背景 随着抖音集团内部对流式任务的需求不断增长&#xff0c;Flink SQL作为一种低成本接入手段&#xff0c;已经在内部多个方向上得到…

K8S系列——(二)、K8S部署RocketMQ集群

1、环境准备 要将RocketMQ部署到K8S上&#xff0c;首先你需要提前准备一个K8S集群环境&#xff0c;如图我已经准备好了一个版本为 v1.28.13 的 K8S 集群&#xff08;其他版本也没问题&#xff09;&#xff1a; 角色IPMaster192.168.6.220Node-1192.168.6.221Node-2192.168.6.…