当前位置: 首页 > news >正文

2.MySQL库的操作

创建数据库

创建数据库的代码:

 CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification] ...];​create_specification:[DEFAULT] CHARACTER SET charset_name[DEFAULT] COLLATE collation_name

说明:

  • 大写的表示关键字

  • [] 是可选项

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

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

注意:如果创建数据库未指明数据库的编码格式或效验规则,则默认使用MySQL配置文件中对应的编码格式或效验规则。

创建数据库案例

创建名为 db1 的数据库

 create database db1;

说明:当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_ general_ ci

指定utf8编码格式创建数据库

我们可以通过charset指明数据库的编码格式,如下:

注意:SQL中的charset=utf8也可以写成charset set = utf8 或者charset set utf8.

创建数据库时通过charset和collater分别指明数据库的编码格式和效验规则即可。如下:

注意:SQL中的collate=utf8_general_ci,也可以写成collate_utf8_general_ci

操纵数据库

查看数据库

使用show database SQL可以查看系统中的所有数据库

显示创建语句

show create database  db1;

说明一下:

  • MySQL 建议我们关键字使用大写,但是不是必须的。
  • 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字。
  • /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话。

修改数据库

ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
说明:
对数据库的修改主要指的是修改数据库的字符集,校验规则
实例: 将 数据库字符集改成 gbk

删除数据库

DROP DATABASE [IF EXISTS] db_ name;
执行删除之后的结果 :
  • 数据库内部看不到对应的数据库
  • 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删

注意:不要随意删除数据库

备份和恢复 -- 放在最后

备份

语法:

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

为了演示数据库的备份和删除,我们先创建一个数据库再说

添加两条数据

查询看一看

mysqldump -P3306 -u root -p -B backup_and_restore > back.sql

打开back.sql的文件即可看到,文件的内容实际就是我们在这个数据库执行的各种SQL命令,包括创建数据库,创建表,修改表,插入语句等一系列语句;

恢复

 现将原本的数据库删掉,show一下查看,放心没有了,接下来开始下面的工程

source back.sql
source 数据库的原路径
mysql> source D:/mysql-5.7.22/mytest.sql;

我们不难看出原本的数据库又回来了

实际恢复数据库的时候就是按照顺序执行数据库备份文件中的SQL语句,执行完毕后也就恢复出来了 

同时该数据库中的表也恢复出来了

表的备份和恢复

新建一个老师表

表备份
mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql

 同时备份多个表 

mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径
表恢复
source 表备份存储的文件路径

查看连接情况

使用show processlist SQL即可查看当前的链接MySQL的用户。

说明一下:

  • Id列:一个标识,可以在MySQL中通过kill id杀死指定id的线程。
  • User列:显示当前用户,如果不是root,这个命令就只显示你权限范围内的SQL语句。
  • Host列:显示这个语句是从哪个IP的哪个端口上发出的,可用来追踪出问题语句的用户。
  • db列:当前执行的命令是在哪一个数据库上,如果没有指定数据库,则该值为NULL。
  • Command列:显示当前连接执行的命令,一般就是休眠(Sleep)、查询(Query)和连接(Connect)。
  • Time列:表示该线程处于当前状态的时间,单位是秒。
  • State列:显示使用当前连接的SQL语句的状态。
  • Info列:一般记录的是线程执行的语句,默认只显示前100个字符,如果要看全部信息,需要使用show full processlist。

show processlist可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登录的,那么很有可能你的数据库被人入侵了,以后如果发现自己的数据库比较慢时,可以用这个SQL来查看数据库连接情况。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • C++ 智能指针简单介绍及用法
  • 微调(二)
  • Java与Python谁更适合后端开发?
  • 计算机网络-七层协议栈介绍
  • Qt pdf文件操作
  • 学习记录day18——数据结构 算法
  • Hadoop学习(三)
  • AI PC处理器架-低功耗、NPU算力、大模型
  • Java面试题--多线程
  • Java基础总结
  • html+css+js前端作业英雄联盟首页1个页面带js
  • 测试面试宝典(四十一)—— 接口自动化的优缺点
  • 关闭窗口工具类 - C#小函数类推荐
  • C++四种类型转换
  • 【课程总结】day19(中):Transformer架构及注意力机制了解
  • 002-读书笔记-JavaScript高级程序设计 在HTML中使用JavaScript
  • 230. Kth Smallest Element in a BST
  • C++入门教程(10):for 语句
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • IndexedDB
  • LeetCode29.两数相除 JavaScript
  • Octave 入门
  • PHP 的 SAPI 是个什么东西
  • Python 使用 Tornado 框架实现 WebHook 自动部署 Git 项目
  • spring学习第二天
  • 浮动相关
  • 给自己的博客网站加上酷炫的初音未来音乐游戏?
  • 类orAPI - 收藏集 - 掘金
  • 使用Gradle第一次构建Java程序
  • 手写一个CommonJS打包工具(一)
  • 微服务入门【系列视频课程】
  • 一个JAVA程序员成长之路分享
  • 用 vue 组件自定义 v-model, 实现一个 Tab 组件。
  • 最近的计划
  • ​​​【收录 Hello 算法】10.4 哈希优化策略
  • # MySQL server 层和存储引擎层是怎么交互数据的?
  • # 职场生活之道:善于团结
  • (C++二叉树05) 合并二叉树 二叉搜索树中的搜索 验证二叉搜索树
  • (C语言)编写程序将一个4×4的数组进行顺时针旋转90度后输出。
  • (PyTorch)TCN和RNN/LSTM/GRU结合实现时间序列预测
  • (一)SpringBoot3---尚硅谷总结
  • .class文件转换.java_从一个class文件深入理解Java字节码结构
  • .Net Core缓存组件(MemoryCache)源码解析
  • .NET CORE使用Redis分布式锁续命(续期)问题
  • .Net 中Partitioner static与dynamic的性能对比
  • .NET/C# 反射的的性能数据,以及高性能开发建议(反射获取 Attribute 和反射调用方法)
  • .net和php怎么连接,php和apache之间如何连接
  • @Autowired注解的实现原理
  • @Controller和@RestController的区别?
  • [AWS]CodeCommit的创建与使用
  • [C#]C# winform部署yolov8目标检测的openvino模型
  • [C#7] 1.Tuples(元组)
  • [Day 16] 區塊鏈與人工智能的聯動應用:理論、技術與實踐
  • [Deep Learning] 神经网络基础
  • [Django ]Django 的数据库操作