【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.rhkb.cn/news/406691.html

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

相关文章

06--kubernetes.pod管理与投射数据卷

前言:上一章记录了部署k8s常用的两个方式,这一章就简单一些,整理一下k8s资源对象的配置和管理命令。 1、集群状态检查 前天搭建的环境,然后关机了两天今天开启后第一时间需要检查集群环境是否正常 [rootk8s-master1 ~]# kubect…

探索《黑神话·悟空》背后的AI技术支持:英伟达全景光线追踪技术、DLSS 3.5 与帧生成

引言 2023 年,游戏《黑神话悟空》以其震撼的视觉效果和深度沉浸的游戏体验,成为全球玩家热议的焦点。这款游戏在发布初期就取得了惊人的销量:预售阶段便突破 120 万套,而发售首日更是达到 450 万份的惊人成绩。这个现象级作品背后…

大模型微调课程及大模型应用开发课程介绍

大模型实验室是在学校现有的实验室建设基础上,依托行业标杆企业,聚焦行业大模型产业发展方向,建设一个产学研一体化的合作教学平台,形成“教与学紧密结合、理论与实践紧密结合,学校与企业紧密结合”的创新教育模式。大…

初识C++以及安装C++学习工具

C的发展史 C是由Bjarne Stroustrup在20世纪80年代初期于贝尔实验室开发的一种编程语言。它的设计初衷是作为C语言的一个超集,通过添加面向对象编程的特性来增强C语言。C支持多种编程范式,包括过程化编程、面向对象编程和泛型编程。 C的历史可以追溯到1…

[数据集][目标检测]道路积水检测数据集VOC+YOLO格式2699张1类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2699 标注数量(xml文件个数):2699 标注数量(txt文件个数):2699 标注…

python-逆序数(赛氪OJ)

[题目描述] 在一个排列中,如果一对数的前后位置与大小顺序相反,即前面的数大于后面的数,那么它们就称为一个逆序。一个排列中逆序的总数就称为这个排列的逆序数。比如一个元素个数为 4 的数列,其元素为 2,4,3,1,则 (2,…

深度优先搜索-放苹果

放苹果 http://noi.openjudge.cn/ch0205/666/ #include<bits/stdc.h> using namespace std;int dfs(int,int); //第一个赋值为1 其余为0 int a[11]{1},ans,n,m;int main(){ int k; cin>>k; for(int i1;i<k;i){ ans0; cin>>m>>n; dfs(m,1);//m个…

Windows C++控制台菜单库开发与源码展示

Windows C控制台菜单库 声明&#xff1a;演示视频&#xff1a;一、前言二、具体框架三、源码展示console_screen_set.hframeconsole_screen_frame_base.hconsole_screen_frame_char.hconsole_screen_frame_wchar_t.hconsole_screen_frame.h menuconsole_screen_menu_base.hcons…

入门 - Vue中使用axios原理分析及解决前端跨域问题

1. 什么是Axios&#xff1f; Axios&#xff08;ajax i/o system&#xff09;&#xff0c;是Vue创建者主推的请求发送方式&#xff0c;因其简单的配置与良好的性能被前端爱好者所喜爱。众所周知&#xff0c;在进行网页设计时经常需要从后端拿数据&#xff0c;在Web应用初期会将…

计算机网络之TCP序号,确认序号和报文传输时间

开篇提示 本篇适合于了解基础知识&#xff0c;进行扩展提高的使用&#xff0c;附带考研习题以及解析。 TCP序号和确认序号的区别 TCP首部中有序号和确认序号&#xff0c;他们都是4个字节&#xff08;4B&#xff09;&#xff0c;且在数据传输中有很重要的意义&#xff0c;那么两…

0x01 GlassFish 任意文件读取漏洞复现

参考文章&#xff1a; 应用服务器glassfish任意文件读取漏洞 - SecPulse.COM | 安全脉搏 fofa 搜索使用该服务器的网站 网络空间测绘&#xff0c;网络空间安全搜索引擎&#xff0c;网络空间搜索引擎&#xff0c;安全态势感知 - FOFA网络空间测绘系统 "glassfish"&…

用TensorFlow实现线性回归

说明 本文采用TensorFlow框架进行讲解&#xff0c;虽然之前的文章都采用mxnet&#xff0c;但是我发现tensorflow提供了免费的gpu可供使用&#xff0c;所以果断开始改为tensorflow&#xff0c;若要实现文章代码&#xff0c;可以使用colaboratory进行运行&#xff0c;当然&#…

外挂程序:增强点及辅助

1.关于前几篇介绍的外挂程序,SAP中的业务单据还是要区分具体的操作人员。如建立财务凭证,工号A,B,C使用相同的SAP账号,那就没办法知道是谁操作的了啊,所以sap的业务单据需要细分到具体人员的都要增强实现以下: 如生产工单: 具体的增强点: 2.辅助程序:SAP账号自动锁定功…

从新手到专家必读书籍:官方推荐.NET技术体系架构指南

前言 Microsoft 官方推荐了一系列有关 .NET 体系结构的指南&#xff0c;旨在帮助开发人员掌握最新的技术和最佳实践。这些资源覆盖了从微服务架构到云原生应用开发等多个主题&#xff0c;是开发高质量 .NET 应用程序不可或缺的参考资料。 通过这些指南&#xff0c;可以深入了…

瑞幸x《黑神话》周边秒空,联名营销真的是流量密码吗?

​8月19日&#xff0c;瑞幸上线了与国产3A游戏《黑神话&#xff1a;悟空》合作的联名活动&#xff0c;其中包括黑神话腾云美式咖啡及周边产品。很多人为了抢到联名的周边&#xff0c;一大早就在瑞幸卡点下单&#xff0c;更有一些网友早上6点多就在瑞幸门口“蹲点”&#xff0c;…

会话跟踪方案:Cookie Session Token

什么是会话技术&#xff1f; Cookie 以登录为例&#xff0c;用户在浏览器中将账号密码输入并勾选自动登录&#xff0c;浏览器发送请求&#xff0c;请求头中设置Cookie&#xff1a;userName:张三 ,password:1234aa &#xff0c;若登录成功&#xff0c;服务器将这个cookie保存…

河南萌新联赛2024第(六)场:郑州大学(补题ABCDFGIL)

文章目录 河南萌新联赛2024第&#xff08;六&#xff09;场&#xff1a;郑州大学A 装备二选一&#xff08;一&#xff09;简单介绍&#xff1a;思路&#xff1a;代码&#xff1a; B 百变吗喽简单介绍&#xff1a;思路&#xff1a;代码&#xff1a; C 16进制世界简单介绍&#x…

【时时三省】(C语言基础)指针进阶2

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 数组指针 是一种指针&#xff0d;是指向数组的指针 整型指针&#xff0d;是指向整形的指针 字符指针&#xff0d;是指向字符的指针 什么叫做数组指针 上面的整形指针跟字符指针只需要&am…

【鸿蒙学习】HarmonyOS应用开发者高级认证 - 一次开发,多端部署

一、学习目的 掌握鸿蒙的核心概念和端云一体化开发、数据、网络、媒体、并发、分布式、多设备协同等关键技术能力&#xff0c;具备独立设计和开发鸿蒙应用能力。 二、总体介绍 HarmonyOS 系统面向多终端提供了“一次开发&#xff0c;多端部署”&#xff08;后文中简称为“一…

日志审计-graylog ssh登录超过6次告警

Apt 设备通过UDP收集日志&#xff0c;在gray创建接收端口192.168.0.187:1514 1、ssh登录失败次数大于5次 ssh日志级别默认为INFO级别&#xff0c;通过系统rsyslog模块处理&#xff0c;日志默认存储在/var/log/auth.log。 将日志转发到graylog vim /etc/rsyslog.conf 文件末…