【MYSQL】MYSQL操作库

1.数据库字符编码集/数据库校验集

当我们在数据库中保存数据时,需要存和取时候编码一致,比方说你用汉语保存的数据,当你读的时候为了避免乱码问题,也必须用汉语读,这就叫做数据库字符编码集一致。
当我们进行查找,比较,读取时候,使用的字段比较编码,叫做数据库的校验集
总结:数据库无论对数据做任何操作,都必须保证操作和编码是一致的(保证不会出现乱码)

2.认识系统编码

show variables like 'character_set_database';//查看系统默认的数据库字符集
在这里插入图片描述

show variables like 'collation_database';//查看系统默认的数据库校验集
在这里插入图片描述

在这里插入图片描述
大多数校验集都是utf-8编码
show charset;//查看数据库支持所有的字符编码集
在这里插入图片描述

show collation;//查看系统中所有的校验集
在这里插入图片描述

3.指定编码创建数据库

当创建了数据库,并且新建表之后,插入数据,会在对应的var/lib/mysql下对应新建数据库目录下形成.opt文件,这个文件里面保存着该数据库的默认编码字符集和默认校准集,但是由于mysql版本太新,8.0之后就不提供db.opt文件了。
create database d2 charset=utf8mb4;//创建数据库,指定字符集为utf8mb4
show create database d2;//查看对应数据库创建时的编码格式
在这里插入图片描述

create database d3 character set utf8mb4;同时这种方法也可以在创建数据库同时指定字符集
create database d4 charset=utf8mb4 collate utf8mb4_0900_ai_ci;//同时创建数据库,设置字符集为utf8mb4,校验集为utf8mb4_0900_ai_ci
当我们在创建数据库时为啥要先配置默认的编码方式呢
为了让第一次创建数据库时,如果没有设置数据库编码格式,就会使用配置时的默认编码方式,如果设置用设置的,没有用系统默认的,设置数据库的编码方式

4.不同校验编码的影响

不区分大小写
创建一个数据库,校验规则使用utf8mb4_general_ci[不区分大小写]
create database test3 charset=utf8mb4 collate utf8mb4_general_ci;//创建数据库,使用如上配置编码集
use test3//在哪个数据库下建表
create table person(name varchar(20));//建一个表,表名为person,表中放名字 占20字节
insert into person values('a'); //插入字符
insert into person values('A');
insert into person values('b');
insert into person values('B');
select * from person;//从person 表中选择全部打印出来
在这里插入图片描述
select * from person where name='a';//在表中查找a,打印处理,发现这种校验集不区分大小写
在这里插入图片描述


区分大小写
创建一个数据库,校验规则使用utf8mb4_bin[区分大小写]
create database test4 charset=utf8mb4 collate utf8mb4_bin;
use test4
create table person(name varchar(20));//建一个表,表名为person,表中放名字 占20字节
insert into person values('a'); //插入字符
insert into person values('A');
insert into person values('b');
insert into person values('B');
select * from person;//从person 表中选择全部打印出来
在这里插入图片描述

在这里插入图片描述
select * from person where name='a';//查找a在当前表中person
在这里插入图片描述

5.操作库的其他操作

创建数据库

create database if not exists d1;
上面的if not exists为可选项目,可加也可不加。
如果存在的话,就不会给你创建
在这里插入图片描述

当创建一个数据库时,对应/var/lib/mysql 目录下多一个目录d1
在这里插入图片描述

删除数据库

在这里插入图片描述
我们就删除之前创建好的d1,先show databases;
发现d1存在。
drop database d1; //删除数据库
在这里插入图片描述

修改数据库

比方说我们要修改test4数据库的字符集和校验集,修改和test3一样

修改前
在这里插入图片描述

alter database test4 charset=utf8mb4 collate utf8mb4_general_ci;//修改数据库编码集

修改后在这里插入图片描述

查看该数据库下有几个表

show tables;

在这里插入图片描述

查看自己目前在哪个数据库

select database(); 在这里插入图片描述

按照ascll码顺序查找

select * from person order by name;
在这里插入图片描述

6.数据库的备份和还原

数据库备份
mysqldump -P3306 -uroot -B test3 >./test3.sql//把test3数据库重定向到当前目录下的test3.sql文件中去
在这里插入图片描述
vim test3.sql//vim打开test3.sql
在这里插入图片描述
这个里面都是对test3数据库的操作


然后删除test3数据库
在这里插入图片描述


数据库的还原

source /root/test3.sql;//source +备份文件的路径
在这里插入图片描述

在这里插入图片描述
如果备份的不是整个数据库,而是其中的一张表
mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql

同时备份多个数据库
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

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

为什么呢?
在这里插入图片描述
在这里插入图片描述
我们发现少了一个创建数据库的默认字符集和校验集,所以我们在恢复的时候,先创建一个空数据库,在use这个数据库,保证使用了默认的字符集和校验集
在这里插入图片描述
相当于备份了test3数据库,但是没有备份创建数据库的字符集和校验集,在恢复的时候就没有默认的字符集和校验集,我们如果在创建一个空的数据库,然后use这个数据库,然后还原的话,就是这个新的数据库就是还原的.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录算法训练营刷题复习1 :动态规划背包问题 01背包+完全背包

动态规划刷题复习 一、01背包 416. 分割等和子集1049. 最后一块石头的重量 II494. 目标和474. 一和零 416. 分割等和子集 class Solution { public:bool canPartition(vector<int>& nums) {int sum0;for(int i0;i<nums.size();i) {sumnums[i];}if(sum%2!0)retu…

Python高级编程:Functools模块的8个高级用法,强烈建议添加到你的开发工具箱中!

目录 1. functools.partial 2. functools.lru_cache lru_cache的特点 cache的特点 性能比较与选择 3. functools.reduce functools.reduce的作用 工作原理 示例 累加序列中的所有元素 计算阶乘 initializer的使用 应用场景 示例:计算平均销售额 小结 4. funct…

不可不知的Java SE技巧:如何使用for each循环遍历数组

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

【面试题】MySQL常见面试题总结

备战实习&#xff0c;会定期给大家整理常考的面试题&#xff0c;大家一起加油&#xff01; &#x1f3af; 系列文章目录 【面试题】面试题分享之JVM篇【面试题】面试题分享之Java并发篇【面试题】面试题分享之Java集合篇&#xff08;三&#xff09; 注意&#xff1a;文章若有错…

StarNet实战:使用StarNet实现图像分类任务(一)

文章目录 摘要安装包安装timm 数据增强Cutout和MixupEMA项目结构计算mean和std生成数据集 摘要 https://arxiv.org/pdf/2403.19967 论文主要集中在介绍和分析一种新兴的学习范式——星操作&#xff08;Star Operation&#xff09;&#xff0c;这是一种通过元素级乘法融合不同子…

[大模型]XVERSE-7B-chat langchain 接入

XVERSE-7B-Chat为XVERSE-7B模型对齐后的版本。 XVERSE-7B 是由深圳元象科技自主研发的支持多语言的大语言模型&#xff08;Large Language Model&#xff09;&#xff0c;参数规模为 70 亿&#xff0c;主要特点如下&#xff1a; 模型结构&#xff1a;XVERSE-7B 使用主流 Deco…

echarts学习:通过图例事件实现选中后控制多条折线的显隐

1.问题描述 我在工作中遇到了这样一个需求&#xff1a;我们都知道点击echarts折线图的图例&#xff0c;是可以控制折线的显隐的。我现在希望点击某一个图例可以改变多条折线的显隐。 例如在下面这张图中&#xff0c;我将“xxx水位”和“yyy水位”分为一组&#xff1b;将“xxx…

521. 最长特殊序列 Ⅰ(Rust单百解法-脑筋急转弯)

题目 给你两个字符串 a 和 b&#xff0c;请返回 这两个字符串中 最长的特殊序列 的长度。如果不存在&#xff0c;则返回 -1 。 「最长特殊序列」 定义如下&#xff1a;该序列为 某字符串独有的最长 子序列 &#xff08;即不能是其他字符串的子序列&#xff09; 。 字符串 s …

【云原生】docker swarm 使用详解

目录 一、前言 二、容器集群管理问题 2.1 docker集群管理问题概述 2.1.1 docker为什么需要容器部署 2.2 docker容器集群管理面临的挑战 三、docker集群部署与管理解决方案 四、Docker Swarm概述 4.1 Docker Swarm是什么 4.1.1 Docker Swarm架构图 4.1.2 Docker Swarm几…

【MySQL】在CentOS环境下安装MySQL

目录 一、卸载残留环境 二、获取官方yum源 三、安装yum源 四、安装MySQL 五、启动MySQL 一、卸载残留环境 输入 ps axj | grep mysql 查看是否存在正在运行的MySQL服务 如果有&#xff0c;则先输入 systemctl stop mysqld 来关闭服务 然后输入 rpm -qa | grep mysql 查看…

Docker MySQL Shutting down mysqld

6月初至6月15日发现MySQL无故停机多次&#xff0c;导致系统无法使用。接下来各种日志查看&#xff0c;排查原因。先附上一份Docker种MySQL的日志的截图。 一、根据Docker的日志初步估计是数据库内存飙升&#xff0c;从而被系统杀掉进程 查询Linux系统日志&#xff0c;在宿主机…

Python武器库开发-武器库篇之Mongodb未授权漏洞扫描器(五十六)

Python武器库开发-武器库篇之Mongodb未授权漏洞扫描器(五十六) MongoDB 未授权访问漏洞简介以及危害 MongoDB是一款非常受欢迎的开源NoSQL数据库&#xff0c;广泛应用于各种Web应用和移动应用中。然而&#xff0c;由于默认配置的不当或者管理员的疏忽&#xff0c;导致不少Mon…

常用串口助手推荐

串口助手作为嵌入式软件工程师最常用的工具&#xff0c;相信大部分的同学都不陌生&#xff0c;这里就不介绍它的使用啦&#xff0c;介绍介绍有哪些好用的款。感兴趣的小伙伴也可以自己去写一个串口助手。 一、SSCOM5.13.1 站内下载资源&#xff1a; https://download.csdn.n…

51单片机STC89C52RC——2.2 独立按键控制LED亮灭Plus

目的 当独立K1按键按一下&#xff08;立即松开&#xff09;&#xff0c;LED D1点亮。再按一下K1&#xff08;立即松开&#xff09;LED D1熄灭。 与前一节《51单片机STC89C52RC——2.1 独立按键控制LED亮灭》当独立K1按键按下时LED D1 点亮&#xff0c;松开D1熄灭 效果不一…

PyTorch 张量数据类型

【数据类型】Python 与 PyTorch 常见数据类型对应&#xff1a; 用 a.type() 获取数据类型&#xff0c;用 isinstance(a, 目标类型) 进行类型合法化检测 >>> import torch >>> a torch.randn(2,3) >>> a tensor([[-1.7818, -0.2472, -2.0684],[ 0.…

单片机与DHT11温湿度检测设计

本次设计是采用STC89C54单片机加上低成本的温湿度模块DHT11构成的温湿度检测系统。设计主要由硬件与软件两部分设计构成。硬件方面包括单片机STC89C54、温湿度模块DHT11、显示模块LCD1602、电池电源、I2C存储器以及控制按键等5个部分。此系统完全基于单片机最小系统并进行一定的…

Open vSwitch 中 vswitchd 事件上报

一、数据包转发流程与 vswitchd 事件上报 Open vSwitch 的数据包转发流程如下图所示&#xff1a; 在数据包的转发流程中&#xff0c;提到过慢速路径的概念&#xff1a;即当数据包在内核空间无法完全处理时&#xff0c;会产生 upcall 调用&#xff0c;将数据包从内核空间转发到用…

XGBoost预测及调参过程(+变量重要性)--血友病计数数据

所使用的数据是血友病数据&#xff0c;如有需要&#xff0c;可在主页资源处获取&#xff0c;数据信息如下&#xff1a; 读取数据及数据集区分 数据预处理及区分数据集代码如下&#xff08;详细预处理说明见上篇文章--随机森林&#xff09;&#xff1a; import pandas as pd im…

RPG游戏完整指南

环境&#xff1a;unity2021urp 本教程教大家如何使用Unity创建一个RPG游戏&#xff0c;玩家可以在城镇场景中进行导航并寻找战斗&#xff0c;并在战斗中遇到不同类型的敌人。玩家可以向敌人施加不同的动作&#xff0c;如&#xff1a;常规攻击和撤离。这会是一个十分有趣的体验。…

AI时代新爬虫:网站自动转LLM数据,firecrawl深度玩法解读

在大模型的时代&#xff0c;爬虫技术也有了很多新的发展&#xff0c;最近出现了专门针对大模型来提取网站信息的爬虫&#xff0c;一键将网页内容转换为LLM-ready的数据。今天我们介绍其中的开源热门代表&#xff1a;firecrawl。 firecrawl 是什么 FireCrawl是一款创新的爬虫工…