文章目录

  • 一、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个库:

  1. information_schema :一个信息数据库,其保存着关于mysql服务器所维护的所有其他数据库的信息,如数据库名,数据库的表,表栏的数据类型与访问权限等;
  2. performance_schema :主要用于收集数据库服务器性能参数;
  3. sys :一个简单版的performance_schema,方便开发人员进行查询;
  4. mysql:存储数据库的用户、权限设置、关键字等mysql自己需要使用的控制和管理信息。

我们还可以用下面的语句来显示创建数据库的语句,并显示字符集:

show create database 数据库名;

说明:

  1. MySQL 建议我们关键字使用大写,但是不是必须的。
  2. 数据库名字的反引号“,是为了防止使用的数据库名刚好是关键字
  3. /*!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;

执行删除之后的结果:

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

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][,columndatatype]...);ALTER TABLE tablename MODIfY (column datatype [DEFAULT expr][,columndatatype]...);ALTER TABLE tablename DROP (column);

例如添加一条记录:

添加一个字段:

修改字段属性:

删除一列:

修改表的名字:

4.删除表