文章目录
- 库的操作
- 1 创建数据库
- 2 创建数据库案例
- 3 字符集和校验规则
- 3.1 查看系统默认字符集以及校验规则
- 3.2 查看数据库支持的字符集
- 3.3 查看数据库支持的字符集校验规则
- 3.4 校验规则对数据库的影响
- 4 操纵数据库
- 4.1 查看数据库
- 4.2 显示创建语句
- 4.3 修改数据库
- 4.4 数据库删除
- 4.5 查看连接情况
库的操作
1 创建数据库
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [, create_specification] ...]
create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
说明:
- 大写的表示关键字
- [] 是可选项
- CHARACTER SET: 指定数据库采用的字符集
- COLLATE: 指定数据库字符集的校验规则
2 创建数据库案例
-
创建名为friends的数据库
create database if not exists friends;
create database if not exists friends;
说明:当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_general_ ci
-
创建一个使用utf字符集,并带校对规则的 frend2数据库。
create database friend2 charset=utf8 collate utf8_general_ci;
3 字符集和校验规则
3.1 查看系统默认字符集以及校验规则
show variables like 'character_set_database';
show variables like 'collation_database';
3.2 查看数据库支持的字符集
show charset;
- 字符集主要是控制用什么语言。比如utf8就可以使用中文
3.3 查看数据库支持的字符集校验规则
show collation;
3.4 校验规则对数据库的影响
- 我们创建两个数据库,一个不区分大小写 ,一个区分大小写
- 不区分大小写
创建一个数据库,校验规则使用utf8_ general_ ci[不区分大小写]
create database test1 collate utf8_general_ci;
1.1 进入数据库
use test1;
1.2 建表
create table person(name varchar(20));
1.3 插入数据
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');
2 . 区分大小写
创建一个数据库,校验规则使用utf8_ bin[区分大小写]
create database test2 collate utf8_bin;
与上面一样的操作
- 进行查询
不区分大小写的查询以及结果
区分大小写的查询以及结果
-
**结果排序 **
不区分大小写排序以及结果:
区分大小写排序以及结果:
4 操纵数据库
4.1 查看数据库
show databases;
4.2 显示创建语句
show create database 数据库名;
-
例:
说明:
- MySQL 建议我们关键字使用大写,但是不是必须的。
- 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
- /*!40100 default… */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话
4.3 修改数据库
-
提示:这里只是学习如何修改,但在实际操作中,不建议轻易的去修改数据库
-
语法:
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]…]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name -
说明:
对数据库的修改主要指的是修改数据库的字符集,校验规则
- 例: 将 friends 数据库字符集改成 gbk
alter database mytest charset=gbk;
- 显示修改结果
show create database friends;
4.4 数据库删除
- 这个就是我们俗称的删除跑路。
DROP DATABASE [IF EXISTS] db_ name;
- 执行删除之后的结果:
- 数据库内部看不到对应的数据库
- 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删
注意:不要随意删除数据库
4.5 查看连接情况
语法:
show processlist
- 例:
可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登陆的,很有可能你的数据库被人入侵了。以后大家发现自己数据库比较慢时,可以用这个指令来查看数据库连接情况。