MYSQL篇二:数据库的操作

文章目录

  • [1. 创建数据库](#1. 创建数据库)
    • [1.1 查看数据库列表](#1.1 查看数据库列表)
    • [1.2 创建与删除数据库](#1.2 创建与删除数据库)
  • [2. 数据的编码问题](#2. 数据的编码问题)
  • [3. 字符集和校验规则](#3. 字符集和校验规则)
    • [3.1 查看系统默认字符集以及校验规则](#3.1 查看系统默认字符集以及校验规则)
    • [3.2 查看数据库支持的字符集](#3.2 查看数据库支持的字符集)
    • [3.3 查看数据库支持的字符集校验规则](#3.3 查看数据库支持的字符集校验规则)
    • [3.4 校验规则对数据库的影响](#3.4 校验规则对数据库的影响)
  • [4. 操纵数据库](#4. 操纵数据库)
    • [4.1 查看当前是哪一个数据库](#4.1 查看当前是哪一个数据库)
    • [4.2 显示创建语句](#4.2 显示创建语句)
    • [4.3 修改数据库](#4.3 修改数据库)
    • [4.4 数据库删除](#4.4 数据库删除)
    • [4.5 备份和恢复](#4.5 备份和恢复)
      • [4.5.1 备份](#4.5.1 备份)
      • [4.5.2 还原](#4.5.2 还原)
      • [4.5.3 注意事项](#4.5.3 注意事项)
    • [4.6 查看连接情况](#4.6 查看连接情况)
  • [5. 表的操作](#5. 表的操作)
    • [5.1 创建表](#5.1 创建表)
    • [5.2 创建表案例](#5.2 创建表案例)
    • [5.3 查看表结构](#5.3 查看表结构)
    • [5.4 修改表](#5.4 修改表)
    • [5.5 删除表](#5.5 删除表)

1. 创建数据库

语法:

sql 复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,
create_specification] ...]

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

说明:

  • 大写的表示关键字
  • \] 是可选项

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

1.1 查看数据库列表

sql 复制代码
show databases;

1.2 创建与删除数据库

本质就是在/var/lib/mysql目录下创建一个目录。

sql 复制代码
create database 数据库的名字;

本质上就是删除目录。

sql 复制代码
drop database 数据库的名字;

2. 数据的编码问题

数据库有两个编码集:

  1. 数据库编码集 --- 数据库未来存储数据
  2. 数据库的校验集 --- 支持数据库,进行字段比较时使用的编码,本质也是一种读取数据库中数据的采用的编码格式。

数据库无论对数据进行任何操作,都必须保证操作和编码必须保持编码一致。

创建一个使用utf8字符集的 db2 数据库:

sql 复制代码
create database db2 charset=utf8;

创建一个使用utf字符集,并带校对规则的 db3 数据库:

sql 复制代码
create database db3 charset=utf8 collate utf8_general_ci;

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

3. 字符集和校验规则

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

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

3.2 查看数据库支持的字符集

sql 复制代码
show charset;

字符集主要是控制用什么语言。比如utf8就可以使用中文。

3.3 查看数据库支持的字符集校验规则

sql 复制代码
show collation;

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

不区分大小写。

创建一个数据库,校验规则使用utf8_ general_ ci[不区分大小写]:

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

区分大小写。

创建一个数据库,校验规则使用utf8_ bin[区分大小写]:

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

4. 操纵数据库

4.1 查看当前是哪一个数据库

sql 复制代码
select database();

4.2 显示创建语句

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

说明:

MySQL 建议我们关键字使用大写,但是不是必须的。

数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字。

/*!40100 default... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话。

4.3 修改数据库

语法:

sql 复制代码
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]

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

说明:

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

实例: 将 test1 数据库字符集改成 gbk。

sql 复制代码
alter database test1 charset=gbk;

4.4 数据库删除

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

执行删除之后的结果:

1. 数据库内部看不到对应的数据库。

2. 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删。

4.5 备份和恢复

4.5.1 备份

语法:

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

示例:将mytest库备份到文件(退出连接)

sql 复制代码
# mysqldump -P3306 -u root -p123456 -B mytest > D:/mytest.sql

这时,可以打开看看 mytest.sql 文件里的内容,其实把我们整个创建数据库,建表,导入数据的语句都装载这个文件中。

4.5.2 还原

sql 复制代码
source D:/mysql-5.7.22/mytest.sql;

4.5.3 注意事项

如果备份的不是整个数据库,而是其中的一张表,怎么做?

sql 复制代码
mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql

同时备份多个数据库:

sql 复制代码
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

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

4.6 查看连接情况

语法:

sql 复制代码
show processlist;

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

5. 表的操作

5.1 创建表

语法:

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

说明:

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

5.2 创建表案例

sql 复制代码
create table users (
	id int,
	name varchar(20) comment '用户名',
	password char(32) comment '密码是32位的md5值',
	birthday date comment '生日'
) character set utf8 engine MyISAM;

说明:

不同的存储引擎,创建表的文件不一样。

users 表存储引擎是 MyISAM ,在数据目中有三个不同的文件,分别是:

  1. users.frm:表结构 (users.sdi)
  2. users.MYD:表数据
  3. users.MYI:表索引

备注:创建一个engine是innodb的数据库,观察存储目录

5.3 查看表结构

查看当前数据库有几张表:

sql 复制代码
show tables;

查看一张表的信息:

sql 复制代码
show create table 表名 \G

查看一张表的结构:

sql 复制代码
desc 表名;

5.4 修改表

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

sql 复制代码
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)

增加一个字段:

sql 复制代码
alter table user add assets varchar(100) comment '图片路径' after birthday;

对原数据没有影响:

修改name,改变其长度为60:

sql 复制代码
alter table user modify name varchar(80);

删除password列:

注意:删除字段一定要小心,删除字段及其对应的列数据都没了。

修改表名字:

sql 复制代码
alter table 原名字 rename to 修改后的名字;

将name列修改为xingming:

5.5 删除表

语法格式:

sql 复制代码
DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...

示例:

sql 复制代码
drop table user1;
相关推荐
nongcunqq2 小时前
abap 操作 excel
java·数据库·excel
rain bye bye3 小时前
calibre LVS 跑不起来 就将setup 的LVS Option connect下的 connect all nets by name 打开。
服务器·数据库·lvs
冻咸鱼3 小时前
MySQL的配置
mysql·配置
阿里云大数据AI技术4 小时前
云栖实录|MaxCompute全新升级:AI时代的原生数据仓库
大数据·数据库·云原生
不剪发的Tony老师5 小时前
Valentina Studio:一款跨平台的数据库管理工具
数据库·sql
weixin_307779135 小时前
在 Microsoft Azure 上部署 ClickHouse 数据仓库:托管服务与自行部署的全面指南
开发语言·数据库·数据仓库·云计算·azure
六元七角八分5 小时前
pom.xml
xml·数据库
虚行5 小时前
Mysql 数据同步中间件 对比
数据库·mysql·中间件
奥尔特星云大使5 小时前
mysql读写分离中间件Atlas安装部署及使用
数据库·mysql·中间件·读写分离·atlas
牛马baby6 小时前
【mysql】in 用到索引了吗?
数据库·mysql·in