MySql:库和表的操作

✨✨作者主页:嶔某✨✨

✨✨所属专栏:MySql✨✨

库的操作

创建数据库

复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,
create_specification] ...]
create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

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

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

创建名为db1的数据库

复制代码
create database db1;

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

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

复制代码
creat database db2 charset=utf8;

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

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

字符集和校验规则

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

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

查看数据库支持的字符集

复制代码
show charset;

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

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

复制代码
show collation;

校验规则对数据库的影响

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

cpp 复制代码
create database test1 collate utf8_general_ci;
cpp 复制代码
use test1;
cpp 复制代码
create table person(name varchar(20));
cpp 复制代码
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');
cpp 复制代码
select * from person where name='a';
cpp 复制代码
select * from person order by name;

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

cpp 复制代码
create database test2 collate utf8_bin;
cpp 复制代码
use test2
cpp 复制代码
create table person(name varchar(20));
cpp 复制代码
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');
cpp 复制代码
select * from person where name='a';
cpp 复制代码
select * from person order by name;

操作数据库

查看数据库

cpp 复制代码
show databases;

显示创建语句

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

修改数据库

cpp 复制代码
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

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

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

cpp 复制代码
mysql> alter database mytest charset=gbk;
Query OK, 1 row affected (0.00 sec)
mysql> show create database mytest;
+----------+----------------------------------------------------------------+
| Database | Create Database |
+----------+----------------------------------------------------------------+
| mytest | CREATE DATABASE `mytest` /*!40100 DEFAULT CHARACTER SET gbk */ |
+----------+----------------------------------------------------------------+

数据库删除(不推荐)

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

执行删除之后的结果:

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

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

备份和恢复

备份

语法:

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

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

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

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

还原

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

注意事项

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

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

同时备份多个数据库

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

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

查看连接情况

语法

cpp 复制代码
show processlist

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

表的操作

创建表

语法

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

说明:

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

说明:

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

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

  • users.frm:表结构
  • users.MYD:表数据
  • users.MYI:表索引

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

查看表结构

cpp 复制代码
desc 表名;

修改表

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

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);

案例:

  • 在users表添加二条记录
cpp 复制代码
insert into users values(1,'a','b','1982-01-04'),(2,'b','c','1984-01-04');
  • 在users表添加一个字段,用于保存图片路径
cpp 复制代码
mysql> alter table users add assets varchar(100) comment '图片路径' after
birthday;

插入新字段后,对原来表中的数据没有影响:

  • 修改name,将其长度改成60
cpp 复制代码
alter table users modify name varchar(60);
  • 删除password列

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

cpp 复制代码
alter table users drop password;
  • 修改表名为employee
cpp 复制代码
alter table users rename to employee; // to可以省掉
  • 将name列修改为xingming
cpp 复制代码
alter table employee change name xingming varchar(60); --新字段需要完整定义

删除表 (不推荐)

语法

cpp 复制代码
DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...
cpp 复制代码
drop table t1

本期博客到这里就结束了,如果有什么错误,欢迎指出,如果对你有帮助,请点个赞,谢谢!

相关推荐
.Eyes1 小时前
OceanBase 分区裁剪(Partition Pruning)原理解读
数据库·oceanbase
苹果醋32 小时前
Java并发编程-Java内存模型(JMM)
java·运维·spring boot·mysql·nginx
MrZhangBaby2 小时前
SQL-leetcode— 2356. 每位教师所教授的科目种类的数量
数据库
一水鉴天2 小时前
整体设计 之定稿 “凝聚式中心点”原型 --整除:智能合约和DBMS的在表层挂接 能/所 依据的深层套接 之2
数据库·人工智能·智能合约
翔云1234563 小时前
Python 中 SQLAlchemy 和 MySQLdb 的关系
数据库·python·mysql
孙霸天3 小时前
Ubuntu20系统上离线安装MongoDB
数据库·mongodb·ubuntu·备份还原
Java 码农3 小时前
nodejs mongodb基础
数据库·mongodb·node.js
TDengine (老段)3 小时前
TDengine IDMP 运维指南(4. 使用 Docker 部署)
运维·数据库·物联网·docker·时序数据库·tdengine·涛思数据
TDengine (老段)3 小时前
TDengine IDMP 最佳实践
大数据·数据库·物联网·ai·时序数据库·tdengine·涛思数据
彬彬醤4 小时前
Mac怎么连接VPS?可以参考这几种方法
大数据·运维·服务器·数据库·线性代数·macos·矩阵