MYSQL库和表的操作(修改字符集和校验规则,备份和恢复数据库及库和表的增删改查)

news2024/11/23 22:39:41

文章目录

  • 一、MSYQL库的操作
    • 1.连接MYSQL
    • 2.查看当前数据库
    • 3.创建数据库
    • 4.字符集和校验规则
    • 5.修改数据库
    • 6.删除数据库
    • 7.备份和恢复
    • 8.查看连接
  • 二、表的操作
    • 1.创建表
    • 2.查看表结构
    • 3.修改表
    • 4.删除表


一、MSYQL库的操作

1.连接MYSQL

我们使用下面的语句来连接MSYQL:

mysql -h 127.0.0.1 -P 3306 -u root -p
-h:登录主机的ip,如果是本地主机登录的话可以忽略
-P:MYSQL的端口,默认是3306,如果未更改可以忽略
-p:用户密码,回车后输入密码即可登录

登录成功后显示如下:

在这里插入图片描述

2.查看当前数据库

我们可以使用下面的语句来查看有哪些数据库:

在这里插入图片描述

系统会默认自带4个库:

  1. information_schema :一个信息数据库,其保存着关于mysql服务器所维护的所有其他数据库的信息,如数据库名,数据库的表,表栏的数据类型与访问权限等;
  2. performance_schema :主要用于收集数据库服务器性能参数;
  3. sys :一个简单版的performance_schema,方便开发人员进行查询;
  4. mysql:存储数据库的用户、权限设置、关键字等mysql自己需要使用的控制和管理信息。

我们还可以用下面的语句来显示创建数据库的语句,并显示字符集:

show create database 数据库名;

在这里插入图片描述

说明:

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

3.创建数据库

我们使用下面的语句来创建数据库:

CREATE DATABASE [IF NOT EXISTS] db_name [create_specification];

create_specification:
[DEFAULT] CHARACTER SET charset_name //指定数据库采用的字符集
[DEFAULT] COLLATE collation_name //指定数据库字符集的校验规则

在这里插入图片描述

4.字符集和校验规则

查看系统默认字符集以及校验规则:

show variables like 'character_set_database';
show variables like 'collation_database';

在这里插入图片描述

系统默认的字符集是utf8,默认的字符集校验规则是utf8_general_ci;

用下面的语句可以查询MYSQL所支持的字符集和校验规则:

在这里插入图片描述
在这里插入图片描述

所以我们可以在创建数据库的时候改变它的字符集和校验规则:

在这里插入图片描述

接下来我们来探讨一下字符集校验规则对数据库的影响:

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');
select * from person where name='a';

我们用上面的语句创建表并查询:

在这里插入图片描述

我们换一种字符集校验规则进行操作:

create database test2 collate utf8_bin;
use test2;
create table person(name varchar(20));
insert into person values('a');
insert into person values('A');
select * from person where name='a';

在这里插入图片描述

所以校验规则使用utf8_ general_ ci(不区分大小写),校验规则使用utf8_ bin(区分大小写)。

5.修改数据库

对数据库的修改主要指的是修改数据库的字符集,校验规则。

例如将数据库test1的字符集改为gbk:

在这里插入图片描述

6.删除数据库

我们使用下面的语句进行删除:

DROP DATABASE [IF EXISTS] db_ name;

执行删除之后的结果:

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

7.备份和恢复

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

我们在存储备份文件的文件夹中执行下面的操作,就可以得到备份文件:

在这里插入图片描述

我们使用vim 打开这个所谓的备份文件,发现其实就是将创建这个库的操作保存下来:

在这里插入图片描述

我们将 test1 数据库删除,并在MYSQL中执行下面的语句恢复数据库:

在这里插入图片描述

注意事项:

如果备份的不是整个数据库,而是其中的一张表,怎么做?
 	mysqldump -u root -p 数据库名 表名1 表名2 > bk.sql
 	
同时备份多个数据库
	mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

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

8.查看连接

下面的语句可以查看当前数据库的连接情况:

在这里插入图片描述

二、表的操作

1.创建表

CREATE TABLE table_name (
field1 datatype,
field2 datatype,
field3 datatype
) character set 字符集 collate 校验规则 engine 存储引擎;

说明:
field 表示列名
datatype 表示列的类型
character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准
collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准

下面是一个创建表的实例:

在这里插入图片描述

那么这些表实际存放在哪呢?我们可以进入var/lib/mysql 目录下:

在这里插入图片描述

我们可以发现在这个目录下,存放了数据库的目录,而我们进入test1 目录:

在这里插入图片描述

在这个目录中,存放的是 test1 数据库中的相关表文件,不同存储引擎的文件会不同。而我们向库中添加一个表,其实就是向对应的目录中存放相关的表信息。

我们再创建一个存储引擎为 InnoDB 的表结构来验证:

在这里插入图片描述

2.查看表结构

在这里插入图片描述

3.修改表

在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。

ALTER TABLE tablename ADD (column datatype [DEFAULT expr][,column
datatype]...);
ALTER TABLE tablename MODIfY (column datatype [DEFAULT expr][,column
datatype]...);
ALTER TABLE tablename DROP (column);

例如添加一条记录:

在这里插入图片描述

添加一个字段:

在这里插入图片描述

修改字段属性:

在这里插入图片描述

删除一列:

在这里插入图片描述

修改表的名字:

在这里插入图片描述

4.删除表

在这里插入图片描述

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

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

相关文章

太阳能 LED 恒流电源 升降压原理图 AP9193 大功率升压恒流IC

特别 宽输入电压范围:3.6V~100V 高效率:可高达 95% 工作频率:1MHz CS 限流保护电压:250mV FB 电流采样电压:250mV 芯片供电欠压保护:2.5V 关断时间可调 外置频率补偿脚 应用领域 LED 灯杯 电池供…

docker容器运维命令

文章目录 docker psdocker execdocker inspectdocker topdocker attachdocker waitdocker exportdocker importdocker portdocker cpdocker diffdocker renamedocker statsdocker update总结 docker ps 列出容器。 docker ps [OPTIONS]OPTIONS说明: -a :显示所有的…

FPGA 通过 UDP 以太网传输 JPEG 压缩图片

FPGA 通过 UDP 以太网传输 JPEG 压缩图片 简介 在 FPGA 上实现了 JPEG 压缩和 UDP 以太网传输。从摄像机的输入中获取单个灰度帧,使用 JPEG 标准对其进行压缩,然后通过UDP以太网将其传输到另一个设备(例如计算机),所有…

计算方法实验1:熟悉MATLAB 环境

一、问题描述 熟悉MATLAB 环境。 二、实验目的 了解Matlab 的主要功能,熟悉Matlab 命令窗口及文件管理,Matlab 帮助系统。掌握命令行的输入及编辑,用户目录及搜索路径的配置。了解Matlab 数据的特点,熟悉Matlab 变量的命名规则&a…

如何独立思考?这里有一份全指南

知乎上有一个问题,叫做:为什么我们要独立思考? 排名第一的回答,是凤凰前主笔王路写的,很有意思。他说: 因为别人告诉我们要独立思考。 这个回答非常妙,也非常反讽,有一种「第22条军规…

32GPIO输入&按键控制LED&光敏控制蜂鸣器

一.硬件 光线越强,光敏电阻的阻值越小 温度越高,热敏电阻的阻值就越小 红外光线越强,红外接收管的阻值就越小 类比:电阻阻值越小,上拉或下拉就越强 (弹簧的拉力就越强) 在上下的电阻分压下&a…

Android Studio 提示Use app:drawableStartCompat instead of android:drawableStart

每次提交代码时,AS这个老妈子总爱唠叨一堆warning,这些Warning都在讲什么? 1.Use app:drawableStartCompat instead of android:drawableStart 在Android开发中,android:drawableStart和app:drawableStartCompat是两个用于设置…

Linux下的进程操作

进程概念 ps -elf:查看操作系统的所有进程(Linux命令) ctrl z:把进程切换到后台 crtl c:结束进程 fg:把进程切换到前台 获取进程进程号和父进程号 函数原型: pid_t getpid(void); //pid_t…

2.精确度-机器学习模型性能常用的评估指标

一.精确度的定义 精确度:机器学习领域中一项至关重要的评价指标,其专注于评估模型对正样本的预测准确性。 相对于准确率而言,精确度更为细致,它关注的是模型在将实例预测为正样本的情况下,实际为正样本的比例。换句话…

2024 1.20~1.26周报

一、上周工作 了解注意力机制,开始论文的初步阅读 二、本周计划 简单了解transform架构,继续研读论文U-MixFormer: UNet-like Transformer with Mix-Attention for Efficient Semantic Segmentation。 三、完成情况——论文研读 标题:U-Mi…

Android双指缩放ScaleGestureDetector检测放大因子大图移动到双指中心点ImageView区域中心,Kotlin(2)

Android双指缩放ScaleGestureDetector检测放大因子大图移动到双指中心点ImageView区域中心,Kotlin(2) 在 Android ScaleGestureDetector检测双指缩放Bitmap基于Matrix动画移动到双指捏合中心点ImageView区域中心,Kotlin-CSDN博客 …

12.Elasticsearch应用(十二)

Elasticsearch应用(十二) 1.单机ES面临的问题 海量数据存储问题单点故障问题 2.ES集群如何解决上面的问题 海量数据存储解决问题: 将索引库从逻辑上拆分为N个分片(Shard),存储到多个节点单点故障问题&a…

自动求导与可微分编程

1.张量的自动求导 1.1 自动求导机制 张量的自动求导机制是现代深度学习框架(如PyTorch和TensorFlow)的核心功能之一,它允许开发者在无需手动计算梯度的情况下,自动获得神经网络中所有参数相对于损失函数的梯度。以下是这一机制的…

Hadoop集群部署流程

前置要求 需要3台虚拟机,系统为Centos7,分别host命名为node1,node2,node3,密码均为root请确保这三台虚拟机已经完成了JDK、SSH免密、关闭防火墙、配置主机名映射等前置操作 在3台虚拟机的/etc/hosts文件中&#xff0…

天津大数据培训班推荐,数据分析过程的常见错误

大数据”是近年来IT行业的热词,目前已经广泛应用在各个行业。大数据,又称海量信息,特点是数据量大、种类多、实时性强、数据蕴藏的价值大。大数据是对大量、动态、能持续的数据,通过运用分析、挖掘和整理,实现数据信息…

Go语言安装及开发环境配置

目录 官网 国内 Linux(CentOS & Ubuntu)安装 环境变量设置 命令行下开发 开发模式执行 编译 IDE下开发 插件安装 安装依赖工具 运行 常见问题 1、dial tcp 172.217.160.113:443: i/o timeout 2、VS Code不能完美显示zsh问题 官网 访问Golang官网的下载链接&a…

matplotlib 波士顿房价数据及可视化 Tensorflow 2.4.0

matplotlib 波士顿房价数据及可视化 Tensorflow 2.4.0 目录 matplotlib 波士顿房价数据及可视化 Tensorflow 2.4.0 1. 认识 1.1 kears 1.2 kears常用数据集 2. 波士顿房价数据及可视化 2.1 下载波士顿房价数据集 2.2 展示一个属性对房价的影响 2.3 将是三个属性全部展…

Redis数据类型及底层实现

文章目录 1.3.1 5种基本数据类型1.3.1.1 总结篇1.3.1.2 底层源码引入篇1.3.1.2.1 redis是字典数据库KV键值对到底是什么1.3.1.2.2 数据类型视角1.3.1.2.3 数据模型解析(重点)1.3.1.2.4 redisObjec1.3.1.2.5 SDS 1.3.1.3 String1.3.1.3.1 底层分析1.3.1.3…

Ubuntu Server 22.04 安装步骤纪录

Ubuntu Server 22.04 安装流程 取得安装程序 安装程序可以通过下方链接直接从官网下载就可以了,官网提供的是iso映像文件,安装前要先将iso映像文件刻录成光盘,或制作成USB开机随身碟。 前往 Ubuntu 官网 开始安装 STEP 1 选择要安装的操作…

Python初学者学习记录——python基础综合案例:数据可视化——地图可视化

一、基础地图使用 1、基础地图演示 2、基础地图演示——视觉映射器 from pyecharts.charts import Map from pyecharts.options import VisualMapOpts# 准备地图对象 map Map() # 准备数据 data [("北京市", 99),("上海市", 199),("湖南省", 2…