「MySQL-02」数据库的操纵、备份、还原和编码规则

目录

一、库操作

1. 创建数据库

2. 查看所有数据库

3. 删除数据库

4. 修改数据库

5. 进入一个数据库

二、查看和设置数据库的编码规则

1. MySQL的两个编码规则:字符集和校验规则

2. 查看MySQL当前使用的字符集以及校验规则

3. 查看MySQL支持的所有字符集

4. 查看MySQL支持的所有校验规则

5. 设置字符集和校验规则

三、数据库的备份和还原

1.数据库的备份和还

2.数据库的还原

四、查看库的连接情况


一、库操作

1. 创建数据库

语法:CREATE DATABASE [IF NOT EXISTS] `数据库名` [charset=要设置的字符集] [collate 要设置的校验规则];
示例:create databse if not exists test charset=utf8;
说明:1.MySQL对大小写不敏感,所以关键字可大写也可小写,MySQL的存储引擎优化后都能识别。2.[] 是可选项3.IF NOT EXISTS:如果不存在就创建。4.数据库名的反引号可加可不加,一般是数据库名称和MySQL中的关键字冲突时加。5.charset: 指定数据库采用的字符集6.collate: 指定数据库字符集的校验规则7.创建数据库的本质就是在 /var/lib/mysql路径下创建目录

2. 查看所有数据库

show databases;
--查看当前用户有权限访问的所有数据库
--本质上就是查看 /var/lib/mysql路径下的目录

3. 删除数据库

语法:DROP DATABASE [IF EXISTS] 数据库名称;
示例:drop database if exists test1;
说明:IF EXISTS:如果存在就删除本质上就是删除 /var/lib/mysql路径下的指定目录,级联删除,里面的数据表全部被删

4. 修改数据库

语法:ALTER DATABASE 数据库名称 [charset 要设置的字符集] [collate 要设置的校验规则];
示例:alter database test charset=utf8;
说明:该sql语句主要就是用来修改数据库的字符集和校验规则,无法修改数据库的名字修改字符集校验规则也会跟着修改但要校验规则如果和当前字符集不匹配将无法修改

5. 进入一个数据库

use 数据库名;
-- 本质上是进入数据库对应的目录

二、查看和设置数据库的编码规则

1. MySQL的两个编码规则:字符集和校验规则

  • 字符集     :规定MySQL以什么编码方式接收、保存用户数据和给发送用户发送数据。
  • 校验规则 :在设立好的字符集的基础上,规定MySQL以什么方式来识别用户发来的SQL语句和比对用户发来的数据跟数据库中的数据,如是否要大小写敏感、是否bin(二元)结束

        MySQl中字符集和校对规则是一对多的关系,虽然字符集都有一个默认的校对规则,但我们可以自主设置字符集和校验规则,只要两者能匹配就不会出现乱码问题。要注意的是只设置字符集时,MySQL会自动将校对规则设置为字符集中对应的默认校对规则。

2. 查看MySQL当前使用的字符集以及校验规则

  • 查看MySQL中数据库使用的字符集以及校验规则:
    show variables like 'character_set_database';
    show variables like 'collation_database';
  • 查看MySQL中数据库服务端使用的字符集以及校验规则:
    show variables like 'character_set_server';
    show variables like 'collation_server';
  • 查看MySQL中各部分使用的字符集以及校验规则:
    show variables like 'character_set_%';
    show variables like 'collation_%';
  • 通过数据库目录下的db.opt文件查看指定数据库使用的字符集以及校验规则
    cat 数据库名称/db.opt

3. 查看MySQL支持的所有字符集

  • SQL语句:
        show charset;
  • 示例: 

        

  • 说明:
        图中第三列即为字符集能匹配上的校验规则。

4. 查看MySQL支持的所有校验规则

  • SQL语句:
        show collation;
  • 示例:
        
  • 说明:
        图中第二列即为校验规则能匹配上的字符集。

5. 设置字符集和校验规则

4.4.1 通过配置my.cnf文件设置MySQL的默认字符集和默认校验规则

示例:

        使用vim打开MySQL配置文件 :  vim /etc/my.cnf

        然后在最后一行前面加上:character-set-server=utf8

        最后重启MySQL客户端 : systemctl restart mysqld 

说明:

        character-set-server=utf8 是在设置MySQL的服务端的默认字符集为utf-8。


4.4.2 创建数据库时指明该数据库使用的字符集和校验规则

SQL语句:

        create database 数据库名 charset 要设置的字符集 collate 要设置的校验规则

示例:

        create database test charset utf8 collate utf8_bin;

说明:

        设置好了字符集,校验规则也会跟着改变为默认匹配的。反之亦然。

        如果创建数据库时不指明该数据库使用的字符集和校验规则,就使用MySQL的默认字符集和默认校验规则。

        设置数据库的字符集,校验规则本质上就是在修改数据库目录下的db.opt文件。


三、数据库的备份和还原

1.数据库的备份和还

语法(在Linux环境下):mysqldump -P端口号 -uMySQL用户名 -p用户密码 -B数据库名 > 存储数据库备份信息的文件的路径
示例:mysqldump -P3306 -uroot -p123456 -Btest > ./db.sql
说明:该语句的主要作用就是将数据库的主要信息和历史操作信息保存到了指定文件中mysqldump和mysql服务端,客户端一样也是由MySQL提供给用户的工具,用来备份数据库。如果备份时,没有-B参数,在恢复数据库时,需要先创建空数据库,然后进入数据库,再使用source来还原如果备份的不是整个数据库,而是其中的一张表,怎么做?mysqldump -u root -p 数据库名 表名1 表名2 > 存储数据库备份信息的文件的路径同时备份多个数据库mysqldump -u root -p -B 数据库名1 数据库名2 ... > 存储数据库备份信息的文件的路径

2.数据库的还原

方法:先登录mysql,再输入以下sql语句:source 保存数据库备份信息的文件路径;
示例source root/mysql/db.sql
说明:这里保存数据库备份信息的文件路径为绝对路径。

四、查看库的连接情况

语法:show processlist说明:用该sql语句我们可以知道当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登陆的,很有可能你的数据库被人入侵了。发现自己数据库比较慢时,可以用这个指令来查看数据库连接情况。

------------------------END-------------------------

才疏学浅,谬误难免,欢迎各位批评指正。

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

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

相关文章

three.js(二):webpack + three.js + ts

用webpackts 开发 three.js 项目 webpack 依旧是主流的模块打包工具;ts和three.js 是绝配,three.js本身就是用ts写的,ts可以为three 项目提前做好规则约束,使项目的开发更加顺畅。 1.创建一个目录,初始化 npm mkdir demo cd de…

centos安装nginx实操记录(加安全配置)

1.下载与安装 yum -y install nginx2.启动命令 /usr/sbin/nginx -c /etc/nginx/nginx.conf3.新建配置文件 cd /etc/nginx/conf.d vim index.conf配了一个负责均衡,如不需要,可将 server localhost: 多余的去掉 upstream web_server{server localhost…

MySQL以及版本介绍

一、MySQL的介绍 MySQL数据库管理系统由瑞典的DataKonsultAB公司研发,该公司被Sun公司收购,现在Sun公司又被Oracle公司收购,因此MySQL目前属于 Oracle 旗下产品。 MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用…

使用爬虫代码获得深度学习目标检测或者语义分割中的图片。

问题描述:目标检测或者图像分割需要大量的数据,如果手动从网上找的话会比较慢,这时候,我们可以从网上爬虫下来,然后自己筛选即可。 代码如下(不要忘记安装代码依赖的库): # -*- co…

《TCP/IP网络编程》阅读笔记--Socket类型及协议设置

目录 1--协议的定义 2--Socket的创建 2-1--协议族(Protocol Family) 2-2--Socket类型(Type) 3--Linux下实现TCP Socket 3-1--服务器端 3-2--客户端 3-3--编译运行 4--Windows下实现 TCP Socket 4-1--TCP服务端 4-2--TC…

C++ sizeof求类型大小

注意内存对齐 struct Stu {int id;char sex;float hight; }; cout<<sizeof(Stu)<<endl; 会输出什么&#xff1f; 字节对齐原则:在系统默认的对齐方式下&#xff1a;每个成员相对于这个结构体变量地址的偏移量正好是该成员类型所占字节的整数倍&#xff0c;且最终…

一、了解[mysql]索引底层结构和算法

目录 一、索引1.索引的本质2.mysql的索引结构 二、存储引擎1.MyISAM2.InnoDB3.为什么建议InnoDB表要建立主键并且推荐int类型自增&#xff1f;4.innodb的主键索引和非主键索引&#xff08;二级索引&#xff09;区别5.联合索引 一、索引 1.索引的本质 索引:帮助mysql高效获取数…

C++------vector【STL】

文章目录 vector的介绍及使用vector的介绍vector的使用 vector的模拟实现 vector的介绍及使用 vector的介绍 1、vector是表示可变大小数组的序列容器。 2、就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问和数…

【前端自动化部署】,Devops,CI/CD

DevOps 提到Jenkins&#xff0c;想到的第一个概念就是 CI/CD 在这之前应该再了解一个概念。 DevOps Development 和 Operations 的组合&#xff0c;是一种方法论&#xff0c;并不特指某种技术或者工具。DevOps 是一种重视 Dev 开发人员和 Ops 运维人员之间沟通、协作的流程。…

第 3 章 栈和队列(单链队列)

1. 背景说明 队列(queue)是一种先进先出(first in first out,缩为 FIFO)的线性表。它只允许在表的一端进行插入&#xff0c;而在另一端删除元素。 2. 示例代码 1&#xff09;status.h /* DataStructure 预定义常量和类型头文件 */#ifndef STATUS_H #define STATUS_H/* 函数结果…

【大数据】Flink 详解(六):源码篇 Ⅰ

Flink 详解&#xff08;六&#xff09;&#xff1a;源码篇 Ⅰ 55、Flink 作业的提交流程&#xff1f;56、Flink 作业提交分为几种方式&#xff1f;57、Flink JobGraph 是在什么时候生成的&#xff1f;58、那在 JobGraph 提交集群之前都经历哪些过程&#xff1f;59、看你提到 Pi…

【个人博客系统网站】统一处理 · 拦截器

【JavaEE】进阶 个人博客系统&#xff08;2&#xff09; 文章目录 【JavaEE】进阶 个人博客系统&#xff08;2&#xff09;1. 统一返回格式处理1.1 统一返回类common.CommonResult1.2 统一返回处理器component.ResponseAdvice 2. 统一异常处理3. 拦截器实现3.1 全局变量SESSI…

Kitchen Hook

双扛厨房排钩&#xff1a;挂刀具

低代码赋能| 绿色智慧矿山解决方案

在世界能源日趋紧张的背景下&#xff0c;能源产业的数字化升级是大势所趋。矿山行业作为国家能源安全的“压舱石”&#xff0c;也必须进行产业升级。一直以来&#xff0c;国家都在大力推动智慧矿山建设。通过大数据、GIS、物联网、云计算、人工智能等新兴技术&#xff0c;实现矿…

Swift 技术 视频播放器滚动条(源码)

一直觉得自己写的不是技术&#xff0c;而是情怀&#xff0c;一个个的教程是自己这一路走来的痕迹。靠专业技能的成功是最具可复制性的&#xff0c;希望我的这条路能让你们少走弯路&#xff0c;希望我能帮你们抹去知识的蒙尘&#xff0c;希望我能帮你们理清知识的脉络&#xff0…

云计算 - 百度AIStudio使用小结

云计算 - 百度AIStudio使用小结 前言 本文以ffmpeg处理视频为例&#xff0c;小结一下AI Studio的使用体验及一些避坑技巧。 算力获得 免费的算力获得方式为&#xff1a;每日登录后运行一个项目&#xff08;只需要点击运行&#xff0c;不需要真正运行&#xff09;即可获得8小…

深入理解 JVM 之——动手编译 JDK

更好的阅读体验 \huge{\color{red}{更好的阅读体验}} 更好的阅读体验 本篇为深入理解 Java 虚拟机第一章的实战内容&#xff0c;推荐在学习前先掌握基础的 Linux 操作、编译原理基础以及扎实的 C/C 功底。 该系列的 GitHub 仓库&#xff1a;https://github.com/Doge2077/lear…

Python爬虫网络安全:优劣势和适用范围分析

目录 优势和劣势 优势&#xff1a; 劣势&#xff1a; 适用范围&#xff1a; 1. 网页数据收集和分析&#xff1a; 2. 漏洞扫描和安全评估&#xff1a; 3. 威胁情报收集&#xff1a; 4. 社交媒体监测和情感分析&#xff1a; 注意事项 1. 合规性和法律规定&#xff1a; …

VB.NET 如何将某个Excel的工作表中复制到另一个的Excel中的工作表中https://bbs.csdn.net/topics/392861034

参考http://share.freesion.com/306372/可以实现直接拷贝指定表 Private Sub Excel复制工作簿()Dim myExcelApp As New Microsoft.Office.Interop.Excel.ApplicationmyExcelApp.Workbooks.Open(System.Environment.CurrentDirectory "\\测试用例.xlsx", Type.Missin…

深入浅出理解Allan方差分析方法

一、参考资料 深入浅出理解卡尔曼滤波 二、Allan方差分析方法 1. 引言 传统的误差指标往往是采用均值误差&#xff08;反映整个误差序列有无宏观偏置&#xff09;、标准差&#xff08;反映整个误差序列的波动情况&#xff09;&#xff0c;以及均方根&#xff08;RMS&#x…