『MySQL快速上手』-③-库的操作

文章目录

  • 1.创建数据库
  • 2.创建数据库案例
  • 3.字符集和校验规则
    • 3.2 校验规则对数据库的影响
      • 3.2.1 进行查询
      • 3.2.2 进行排序
  • 4.字符集和检验规则的作用
  • 5.操纵数据库
    • 5.1 查看数据库
    • 5.2 显示创建语句
    • 5.3 修改数据库
    • 5.4 数据库删除
  • 6.备份与恢复
    • 6.1 备份
    • 6.2 还原
    • 6.3 注意事项
  • 7.查看数据库连接情况

在这里插入图片描述

1.创建数据库

语法格式如下:

CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,
create_specification] ...]

create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

  • 大写的表示关键字(SQL指令是大小写忽略的,小写也没问题);

  • [] 是可选项;

  • CHARACTER SET: 指定数据库采用的字符集

  • COLLATE: 指定数据库字符集的校验规则

2.创建数据库案例

  • 创建数据库,命名为db1
create database db1

说明:

当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集utf8,校验规则是:utf8_ general_ ci。这由MySQL的配置文件决定。

  • 查看MySQL配置文件
cat /etc/my.cnf

在这里插入图片描述

  • 创建一个使用utf8字符集db2 数据库;
create database db2 charset=utf8;
  • 创建一个使用utf8字符集,并带校对规则的 db3 数据库;
create database db3 charset=utf8 collate utf8_general_ci;

3.字符集和校验规则

  • 查看系统默认字符集以及校验规则
show variables like 'character_set_database';
show variables like 'collation_database';

在这里插入图片描述

  • 查看数据库支持的字符集
show charset;
  • 查看数据库支持的字符集校验规则
show collation;

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

我们可以从下面这个示例中看出校验规则对数据库的影响。

  1. 创建一个数据库,校验规则使用utf8_ general_ ci(不区分大小写);
create database test1 collate utf8_general_ci;
use test1;
create table person(name varchar(20));
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');
  1. 创建一个数据库,校验规则使用utf8_ bin(区分大小写);
create database test2 collate utf8_bin;
use test2;
create table person(name varchar(20));
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');

3.2.1 进行查询

  • 不区分大小写的查询以及结果
use test1;
select * from person where name='a';

在这里插入图片描述

  • 区分大小写的查询以及结果;
use test2;
select * from person where name='a';

在这里插入图片描述

3.2.2 进行排序

  • 不区分大小写排序以及结果:
use test1;
select * from person order by name;

在这里插入图片描述

  • 区分大小写排序以及结果:

在这里插入图片描述

4.字符集和检验规则的作用

数据库中的字符集(Character Set)和字符集校验规则(Collation)是用于定义和管理数据库中文本数据存储和比较的重要设置。它们的作用如下:

  1. 字符集(Character Set):

    • 定义了数据库中可以存储的字符集合,包括字母、数字、符号等。
    • 确定了数据库如何存储和表示不同字符和符号。
    • 不同的字符集支持不同的字符编码方式,如UTF-8、UTF-16、ISO-8859-1等。
    • 可以影响文本数据的存储空间和性能。
  2. 字符集校验规则(Collation):

    • 确定了文本数据的比较和排序方式,即如何对文本数据进行比较、搜索和排序。
    • 根据字符集校验规则,相同的字符可能在排序时被视为不同。
    • 支持不同语言和文化的排序规则,以确保文本数据的正确比较和排序。
    • 不同的字符集校验规则可能会影响查询结果的顺序和比较操作的行为。

这些设置对数据库的正确性、性能和多语言支持非常重要。以下是一些具体作用:

  • 数据完整性:字符集和字符集校验规则有助于确保数据存储的一致性和正确性。它们防止了不同字符之间的混淆,确保数据正确存储和检索。

  • 多语言支持:不同语言使用不同的字符集和校验规则,因此数据库必须支持多种字符集和校验规则,以适应不同语言的数据。

  • 搜索和排序:字符集校验规则决定了文本数据的搜索和排序方式。它们确保文本数据按照正确的规则进行比较和排序,以获得正确的查询结果。

  • 存储空间效率:不同字符集和编码方式可以影响数据存储的空间效率。例如,某些字符集需要更多的存储空间来表示特定字符。

  • 数据交互:当与其他系统或应用程序进行数据交互时,字符集和字符集校验规则的一致性非常重要,以确保数据正确传输和解释。

总之,字符集和字符集校验规则是数据库中用于管理文本数据的关键设置,它们影响了数据的正确性、性能和多语言支持,因此在创建和维护数据库时需要特别注意。

5.操纵数据库

5.1 查看数据库

show databases;

在这里插入图片描述

5.2 显示创建语句

show create database 数据库名;

在这里插入图片描述
说明:

  • 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  • /*!40100 default… */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话;

5.3 修改数据库

语法格式如下:

ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]

alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
  • 对数据库的修改主要指的是修改数据库的字符集,校验规则

案例——将test1数据库字符集改成gbk

alter database test1 charset=gbk;

在这里插入图片描述

5.4 数据库删除

语法格式如下:

DROP DATABASE [IF EXISTS] db_ name;

执行删除之后的结果:

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

6.备份与恢复

6.1 备份

语法格式如下:

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

案例——将test1库备份到文件

  • 首先退出mysql;

  • test1备份到 ./test1.sql

$ mysqldump -P3306 -u root -p -B test1 > ./test1.sql
  • 查看备份文件test1.sql;
  • test1.sql 文件里的内容,其实把我们整个创建数据库,建表,导入数据的语句都装载这个文件中;
$ cat ./test1.sql

在这里插入图片描述

6.2 还原

  • 登入MySQL,删除test1
drop database test1;
show databases;

在这里插入图片描述

  • 还原;
source ./test1.sql;
show databases;

在这里插入图片描述

6.3 注意事项

  • 如果备份的不是整个数据库,而是其中的一张表,怎么做?
$ mysqldump -u root -p 数据库名 表名1 表名2 > 备份文件路径
  • 同时备份多个数据库
$ mysqldump -u root -p -B 数据库名1 数据库名2 ... > 备份文件路径
  • 如果备份一个数据库时,没有带上-B参数, 在恢复数据库时,需要先创建空数据库,然后使用数据库,再使用source来还原;

7.查看数据库连接情况

语法:

show processlist

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

在这里插入图片描述

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

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

相关文章

[量化投资-学习笔记007]Python+TDengine从零开始搭建量化分析平台-布林带

布林带(Bollinger Bands)也称为布林通道、保力加通道,是由约翰布林格(John Bollinger)发明的技术分析指标。布林通道通常被用来确认资产价格波动范围。 布林通道是由三条平滑的曲线组成的趋势线图表,中线为…

js原型链

什么叫原型链 原型链是js中的核心,原型链将各个属性链接起来,在原型链上面定义,原型链上的其他属性能够使用,原型链就是保证继承 原型链区分 原型链分为显式原型和隐式原型 显式原型:只有函数和构建函数才有显式原型…

CCF CSP认证 历年题目自练Day44

题目一 试题编号: 201612-3 试题名称: 权限查询 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述   授权 (authorization) 是各类业务系统不可缺少的组成部分,系统用户通过授权机制获得系统中各个…

[ACTF2020 新生赛]BackupFile 1

题目环境: 好好好,让找源文件是吧?咱们二话不说直接扫它后台 使用dirsearch工具扫描网站后台(博主有这个工具的压缩包,可以私聊我领取)python dirsearch.py -u http://0d418151-ebaf-4f26-86b2-5363ed16530…

01-基于IDEA,Spring官网,阿里云官网,手动四种方式创建SpringBoot工程

快速上手SpringBoot SpringBoot技术由Pivotal团队研发制作,功能的话简单概括就是加速Spring程序初始搭建过程和Spring程序的开发过程的开发 最基本的Spring程序至少有一个配置文件或配置类用来描述Spring的配置信息现在企业级开发使用Spring大部分情况下是做web开…

基于机器学习的 ICU 脑血管疾病死亡风险智能预测系统

温馨提示:文末有 CSDN 平台官方提供的学长 Wechat / QQ 名片 :) 1. 项目简介 重症患者或重大手术后的患者在重症监护室(ICU)内通过多种生命支持系统以维持生理功能。患者在ICU 内会被频繁持续的记录生命体征和实验室测量等多种数据。由于高频…

为什么有了MAC地址,还需要IP地址?

解释 搞懂这个问题,首先需要了解交换机的功能 交换机内部有一张MAC地址映射表,记录着MAC地址和端口的对应关系。 如果A要给B发送一个数据包,构造如下格式的数据结构: 到达交换机时,交换机内部通过自己维护的 MAC 地…

b2b.ccb.com:443 需要你的凭据

忙活了一天,晚上回来准备查一下公户的最近的账单。因为昨天晚上熬夜重新做了电脑系统,就下载了建设银行的E路护航,一切安装就绪,准备进入企业网银时,被这些垃圾搞的系统及软件恶心到了,在此记录一下&#x…

Flutter利用GridView创建网格布局实现优美布局

文章目录 简介使用详解导入依赖项创建一个基本的 GridView一些参数说明使用GridView.count来构造 其他控制总结 简介 GridView 是 Flutter 中用于创建网格布局的强大小部件。它允许你在行和列中排列子小部件,非常适合显示大量项目,例如图像、文本、卡片…

js树形数组遍历练习,扁平化、格式化、获取节点父级

1.树形数组扁平化 数组扁平化的方式很多,这里主要是用递归处理,除此之外还有正则、扩展运算符等等 const list [{name:1,id:1,children:[{name:11,id:11,children:[{name:111,id:111}]},{name:12},]},{name:2,id:2,children:[{name:21,id:21,children:…

数据结构-栈和队列(一)

目录 1.栈 1.1 栈的概念及结构 1.2 栈的实现 初始化栈: 入栈: 判空函数: 出栈: 获取栈顶元素: 获取栈中有效元素的个数: 销毁栈: 完整代码: 测试: 2. 队列 …

在 Python 中使用 Selenium 按文本查找元素

我们将通过示例介绍在Python中使用selenium通过文本查找元素的方法。 在 Python 中使用 Selenium 按文本查找元素 软件测试是检查应用程序是否满足用户需求的技术。 该技术有助于使应用程序成为无错误的应用程序。 软件测试可以手动完成,也可以通过某些软件完成。…

解决Docker启动之npm版本不兼容问题

报错内容: npm WARN read-shrinkwrap This version of npm is compatible with lockfileVersion1, but package-lock.json was generated for lockfileVersion2. Ill try to do my best with it! npm WARN tar ENOENT: no such file or directory, open /home/wvp-…

ConcurrentHashMap 底层具体实现知道吗?实现原理是什么?

(本文引自mic老师文档) 之前分享过一期 HashMap 的面试题,然后有个小伙伴私信我说,他遇到了一个 ConcurrentHashMap 的问题不知道怎么回答。 于是,就有了这一期的内容!! …

Skywalking介绍

一个优秀的项目,除了具有高拓展的架构、高性能的方案、高质量的代码之外,还应该在上线后具备多角度的监控功能。现在企业中的监控服务也有很多,Skywalking除了提供多维度、多粒度的监控之外,也提供了良好的图形化界面以及性能剖析…

Python--- lstrip()--删除字符串两边的空白字符、rstrip()--删除字符串左边的空白字符、strip()--删除字符串右边的空白字符

strip() 方法主要作用:删除字符串两边的空白字符(如空格) lstrip() 方法 left strip,作用:只删除字符串左边的空白字符 rstrip() 方法,作用:只删除字符串右边的空白字符 strip 英 /strɪp…

Ansible playbook自动化运维工具详解

Ansible playbook自动化运维工具详解 一、playbook的相关知识1.1、playbook 的简介1.2、playbook的 各部分组成 二、基础的playbook剧本编写实例三、 playbook的定义、引用变量3.1、基础变量的定义与引用3.2、引用fact信息中的变量 四、playbook中的when条件判断和变量循环使用…

P02项目诊断报警组件(学习操作日志记录、单元测试开发)

★ P02项目诊断报警组件 诊断报警组件的主要功能有: 接收、记录硬件设备上报的报警信息。从预先设定的错误码对照表中找到对应的声光报警和蜂鸣器报警策略,结合当前的报警情况对设备下发报警指示。将报警消息发送到消息队列,由其它组件发送…

Collection集合 迭代器遍历Iterator 和集合增强For

迭代器遍历Iterator 标准写法: 增强For for(类型 名称 : 集合 ) 举例: 不仅可以集合也可以数组 底层仍然是iterator

设计模式—结构型模式之装饰器模式

设计模式—结构型模式之装饰器模式 适配器是连接两个类,可以增强一个类,装饰器是增强一个类。 向一个现有的对象添加新的功能,同时又不改变其结构。属于对象结构型模式。 创建了一个装饰类,用来包装原有的类,并在保…