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

文章目录


一、MSYQL库的操作

1.连接MYSQL

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

cpp 复制代码
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自己需要使用的控制和管理信息。

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

cpp 复制代码
show create database 数据库名;

说明:

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

3.创建数据库

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

cpp 复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification];

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

4.字符集和校验规则

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

cpp 复制代码
show variables like 'character_set_database';
show variables like 'collation_database';

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

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


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

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

cpp 复制代码
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';

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

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

cpp 复制代码
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.删除数据库

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

cpp 复制代码
DROP DATABASE [IF EXISTS] db_ name;

执行删除之后的结果:

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

7.备份和恢复

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

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

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

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

注意事项:

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

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

8.查看连接

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

二、表的操作

1.创建表

cpp 复制代码
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.修改表

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

cpp 复制代码
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.删除表

相关推荐
Elastic 中国社区官方博客17 分钟前
使用 Elasticsearch 导航检索增强生成图表
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
小金的学习笔记21 分钟前
RedisTemplate和Redisson的使用和区别
数据库·redis·缓存
新知图书36 分钟前
MySQL用户授权、收回权限与查看权限
数据库·mysql·安全
文城5211 小时前
Mysql存储过程(学习自用)
数据库·学习·mysql
沉默的煎蛋1 小时前
MyBatis 注解开发详解
java·数据库·mysql·算法·mybatis
呼啦啦啦啦啦啦啦啦1 小时前
【Redis】事务
数据库·redis·缓存
HaoHao_0101 小时前
AWS Serverless Application Repository
服务器·数据库·云计算·aws·云服务器
C语言扫地僧1 小时前
MySQL 事务及MVCC机制详解
数据库·mysql
小镇cxy1 小时前
MySQL事物,MVCC机制
数据库·mysql
书生-w2 小时前
Redis Windows 解压版安装
数据库·windows·redis