1.库的操作
1.1创建数据库
创建数据库
语法:
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification] ...]
create_specification:
[DEFAULT] CHARACTER SET charset_name #字符集
[DEFAULT] COLLATE collation_name #校验规则
[] 是可选项,也就表示着括号内的内容可填可不填的。
- IF NOT EXISTS:表示判断下创建的库是否存在(若创建的文件存在了就会报错误信息)
实例:
查看所有已创建的库:
show databases;
创建database1数据库:
create database database1;
删除database1数据库:
drop database database1;
1.1.1设置库的字符集和校验规则
当我们创建数据库没有指定字符集和校验规则时,系统一般使用的默认字符集:utf8,校验规则是:utf8_ general_ ci(在配置文件中写的)
语法:
create database dbname charset=字符集 collate 校验规则;
单独的设置字符集:
在Linux下就是在该数据库文目录下的db.opt文加下存着字符集和校验集。
注意的是当库确定了字符集、校验集,当在该库下创建表时会继承库的编码格式。
1.1.2查看系统默认字符集以及校验规则:
创建数据库的时候有两个编码集:
- 数据库字符集 — 数据库未来存储的数据
- 数据库校验集 — 支持数据库,进行字段比较时使用的编码,本质是一种读取数据库中数据的采用的编码格式
写和读的编码集必须是统一的,也就是数据库无论对数据的任何操作,都必须保证操作和编码必须保持一致
查看字符集:
show variables like 'character_set_database';
查看校验集;
show variables like 'collation_database';
附:
查看数据库支持的字符集和校验规则:
查看数据库所有支持的字符集:
show charset;
查看数据库支持的校验规则:
show collation;
1.1.3校验规则对数据库的影响
不同的校验规则对数据库是不同的,很好理解,不同的校验规则,也就表明了不同的比较方法
而上面所用到的的utf8_general_ci是不区分大小写的、而utf8_bin区分大小写
验证utf8_general_ci是不区分大小写的如下(附:db数据库的校验规则是utf_general_ci):
下面对于表的操作先认识即可:
上图发现查找时a、A同时查出来了,所以也表示他们是一样的,故是不区分大小写的。
在表中查找某个数据
语法:
select * from table_name where row_name=check_information;
具体使用:
select * from person where name='a';
排序方法验证(默认升序)
语法:
select * from table_name order by Row_name;
具体使用:
select * from person order by name;
utf8_bin区分大小写的:
上图只查出了一个就表示是区分大小写的(a!=A)
排序(默认升序):
语法:
select * from table_name order by Row_name;
具体使用:
select * from person order by name;
一般来说我们并不需要去设置编码集,因为在数据库配置时,我们就已经设置好了。
1.2删除数据库
语法:
DROP DATABASE [IF EXISTS] db_ name;
例:
drop database database1;
附:强烈不建议轻易的删除数据库
执行删除之后的结果:
- 数据库内部看不到对应的数据库
- 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删
1.3查看数据库
查看数据库的语法:
show databases;
1.3.1查看当前所在数据库:
select database();
如当前在db数据库下:
1.3.2显示创建库的语句
语法:
show create database dbname; #dbname就是数据库名
- 其中在查看到创建库的语句中的 /*!40100 default… */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话
1.4修改数据库
1.4.1修改校验规则
语法:
ALTER DATABASE db_name [alter_spacification [,alter_spacification]...]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name #字符集
[DEFAULT] COLLATE collation_name #校验规则
具体使用sql语句方法:
alter database db charset=gbk collate gbk_general_ci;
2.数据库中的备份和恢复
2.1备份数据:
通过在服务器上输入bash指令:
备份库:
mysqldump -P3306 -uroot -p -B db > db.sql
将会生成一个db.sql备份文件
查看内部内容的语法:
vim db.sql
内部内容就是在数据库主要的sql语句:
2.2恢复数据
source 备份文件的路径;
附:
备份某张表(恢复一样)
mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql
其实也就发现和备份库不一样的是少了 -B 选项,所以也就表明了 -B 选项的含义就是在备份文件中加一个创建数据库的SQL语句
同时也侧面说明了,该还原时是需要在一个已经创建好的数据库下使用source来进行还原的!
同时备份多份数据库(也很简单类似于备份一个数据库)
mysql -uroot -p -B 数据库名1 数据库名2 ... > 数据库存放的路径
查看连接状态(那些用户在使用)
show processlist;