文章目录
- 一、MSYQL库的操作
- 1.连接MYSQL
- 2.查看当前数据库
- 3.创建数据库
- 4.字符集和校验规则
- 5.修改数据库
- 6.删除数据库
- 7.备份和恢复
- 8.查看连接
- 二、表的操作
- 1.创建表
- 2.查看表结构
- 3.修改表
- 4.删除表
一、MSYQL库的操作
1.连接MYSQL
我们使用下面的语句来连接MSYQL:
mysql -h 127.0.0.1 -P 3306 -u root -p
-h:登录主机的ip,如果是本地主机登录的话可以忽略
-P:MYSQL的端口,默认是3306,如果未更改可以忽略
-p:用户密码,回车后输入密码即可登录
登录成功后显示如下:
2.查看当前数据库
我们可以使用下面的语句来查看有哪些数据库:
系统会默认自带4个库:
- information_schema :一个信息数据库,其保存着关于mysql服务器所维护的所有其他数据库的信息,如数据库名,数据库的表,表栏的数据类型与访问权限等;
- performance_schema :主要用于收集数据库服务器性能参数;
- sys :一个简单版的performance_schema,方便开发人员进行查询;
- mysql:存储数据库的用户、权限设置、关键字等mysql自己需要使用的控制和管理信息。
我们还可以用下面的语句来显示创建数据库的语句,并显示字符集:
show create database 数据库名;
说明:
- MySQL 建议我们关键字使用大写,但是不是必须的。
- 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
- /*!40100 default… */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话
3.创建数据库
我们使用下面的语句来创建数据库:
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification];
create_specification:
[DEFAULT] CHARACTER SET charset_name //指定数据库采用的字符集
[DEFAULT] COLLATE collation_name //指定数据库字符集的校验规则
4.字符集和校验规则
查看系统默认字符集以及校验规则:
show variables like 'character_set_database';
show variables like 'collation_database';
系统默认的字符集是utf8,默认的字符集校验规则是utf8_general_ci;
用下面的语句可以查询MYSQL所支持的字符集和校验规则:
所以我们可以在创建数据库的时候改变它的字符集和校验规则:
接下来我们来探讨一下字符集校验规则对数据库的影响:
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';
我们用上面的语句创建表并查询:
我们换一种字符集校验规则进行操作:
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.删除数据库
我们使用下面的语句进行删除:
DROP DATABASE [IF EXISTS] db_ name;
执行删除之后的结果:
- 数据库内部看不到对应的数据库;
- 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删;
7.备份和恢复
语法:
mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径
我们在存储备份文件的文件夹中执行下面的操作,就可以得到备份文件:
我们使用vim 打开这个所谓的备份文件,发现其实就是将创建这个库的操作保存下来:
我们将 test1 数据库删除,并在MYSQL中执行下面的语句恢复数据库:
注意事项:
如果备份的不是整个数据库,而是其中的一张表,怎么做?
mysqldump -u root -p 数据库名 表名1 表名2 > bk.sql
同时备份多个数据库
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径
如果备份一个数据库时,没有带上-B参数, 在恢复数据库时:
需要先创建空数据库,然后使用数据库,再使用source来还原。
8.查看连接
下面的语句可以查看当前数据库的连接情况:
二、表的操作
1.创建表
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.修改表
在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。
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);
例如添加一条记录:
添加一个字段:
修改字段属性:
删除一列:
修改表的名字: